Utworzenie wydajnego systemu dla wypozyczalni hulajnog.
- Wyszukiwanie najblizszych dostepnych hulajnog w okolicy
- Pobranie wypozyczonych hulajnog
- Pobranie dostepnych hulajnog
- Pobranie aktualnego połozenia hulajnog
- Rezerwacja wybranej hulajnogi na 15 min.
docker run --name bitconf-redis -d -p 6379:6379 redis
Uruchomienie trybu interaktywnego
docker exec -it bitconf-redis redis-cli
Uruchomienie kontenera
docker start bitconf-redis
Zatrzymanie kontenera
docker stop bitconf-redis
Sprawdzenie czy Redis odpowiada
ping
Śledzenie Redisa
monitor
Dodanie wartości
SET current:user Marcin
Kolejne wywołanie nadpisze poprzednią wartość (update).
Jeśli chcemy tego uniknąć należy dodać atrybut NX
SET current:user Marcin NX
Pobranie wartości
GET current:user
Usunięcie klucza
DEL current:user
Dodanie wartości na określony czas (TTL)
set vehicle1 ready ex 120
Ustawienie czasu życia klucza
expire vehicle1 60
Pobranie czasu, który pozostał do wygaśnienia klucza
ttl vehicle1
Pobranie wszystkich kluczy wg szablonu
keys *
Dodanie 1 do klucza
incr points
Dodanie określonej liczby do klucza
incrby points 10
Odjęcie 1 od klucza
decr points
Odjęcie określonej liczby do klucza
decrby points 10
Ustawienie bitu
setbit article1:today 50 1
setbit article2:today 50 1
setbit article2:today 50 1
Pobranie bitu
getbit article1:today 50
Operacja AND
bitop and 50:readboth article1:today article2:today
Operacja OR
bitop or 50:readanyarticle article1:today article2:today
Obliczenie ilości ustawionych bitów na 1
bitcount result
Wybór bazy danych
select 1
Jeśli chcesz zmodyfikować cały obiekt zwykły string wystarczy:
SET users:marcin { 'email': '[email protected]', speed: 120}
Natomiast w przypadku, gdy chcesz mieć dostęp do pojedynczych pól lepszym rozwiązaniem będą tablice asosjacyjne.
Dodanie
HSET users:marcin email [email protected]
HSET users:marcin speed 120
Pobranie wybranego pola
HGET users:marcin email
Dodanie wielu wartości
HMSET users:marcin speed 120 email [email protected]
Pobranie wszystich pól
HGETALL users:marcin
Ustawienie czasu życia
EXPIRE users:Marcin
Wstawianie elementu do listy (na początek)
lpush pages page1
lpush pages page2
lpush pages page3
Pobranie elementów z listy na podstawie zakresu
lrange pages 0 3
Usunięcie i pobranie pierwszego elementu z listy
lpop pages
Usunięcie i pobranie ostatniego elementu z listy
rpop pages
Dołączenie elementu do listy (na koniec)
lpush orders order1
lpush orders order2
lpush orders order3
Pobranie elementu z listy na podstawie indeksu
lindex orders 2
Ustawienie wartości elementu na liście na podstawie indeksu
lset orders 2 order10
Usunięcie określonej ilości elementów z listy począwszy od podanej wartości
lrem ordered 2 order5
Usunięcie ostatniego elementu z listy, dołączenie go do innej listy i zwrócenie
rpoplpush ordered delivered
Dodanie wartości do zbioru
sadd online user1
sadd online user2
sadd online user3
sadd offline user4
sadd offline user5
Pobranie elementów zbioru
smembers online
Usunięcie elementu ze zbioru
srem online user1
Przesunięcie elementu pomiędzy zbiorami
smove offline online user5
Suma zbiorów
sunion online offline
Część wspólna zbiorów
sinter online offline
Różnica zbiorów
sdiff
Dodanie elementów
ZADD skills:marcin 100 csharp
ZADD skills:marcin 94 wpf-mvvm
ZADD skills:marcin 2 python
Pobranie elementów wg rankingu
ZRANGEBYSCORE skills:marcin 50 100
Dodanie pozycji
geoadd locations 52.361389 19.115556 Vehicle1
geoadd locations 52.361389 19.115556 Vehicle2
geoadd locations 52.361389 19.115556 Vehicle3
geoadd locations 52.361389 19.115556 Vehicle4
Pobranie pozycji określonego klucza
geopos locations Vehicle2
Obliczenie dystansu pomiędzy dwoma pozycjami
geodist locations Vehicle1 Vehicle4 km
Wyszukanie pozycji w określonym promieniu
georadius locations 0 0 200 km
Wyczyszczenie wszystkich kluczy ze wszystkich baz danych
flushall
Wyczyszczenie wszystkich kluczy z bieżącej bazy danych
flushdb
Wyczyszczenie wszystkich kluczy z określonej bazy danych
-n <database_number> flushdb
Utworzenie subskrypcji
subscribe sensors:temp1
Wysłanie wiadomości
publish sensors:temp1 54.21
Usunięcie subskrypcji
UNSUBSCRIBE
Utworzenie subskrypcji ze wzorcem
psubscribe sensors.temp*
-
dotnet --list-sdks
- wyświetlenie listy zainstalowanych SDK -
dotnet --list-runtimes
- wyświetlenie listy zainstalowanych środowisk uruchomieniowych -
dotnet new globaljson
- utworzenie pliku global.json -
dotnet new globaljson --sdk-version {version}
- utworzenie pliku global.json i ustawienie wersji SDK -
dotnet new gitignore
- utworzenie pliku gitignore -
dotnet new sln
- utworzenie nowego rozwiązania -
dotnet sln {solution.sln} add {project.csproj}
- dodanie projektu do rozwiązania -
dotnet sln {solution.sln} remove {project.csproj}
- usunięcie projektu z rozwiązania -
dotnet new {template}
- utworzenie nowego projektu na podstawie wybranego szablonu -
dotnet new {template} -o {output}
- utworzenie nowego projektu w podanym katalogu -
dotnet add {project.csproj} reference {library.csproj}
- dodanie odwołania do biblioteki -
dotnet remove {project.csproj} reference {library.csproj}
- usunięcie odwołania do biblioteki -
dotnet restore
- pobranie bibliotek nuget na podstawie pliku projektu -
dotnet build
- kompilacja projektu -
dotnet run
- uruchomienie projektu -
dotnet run {app.dll}
- uruchomienie aplikacji -
dotnet test
- uruchomienie testów jednostkowych -
dotnet run watch
- uruchomienie projektu w trybie śledzenia zmian -
dotnet test watch
- uruchomienie testów jednostkowych w trybie śledzenia zmian -
dotnet publish -c Release -r {platform}
- publikacja aplikacji -
dotnet publish -c Release -r win10-x64
- publikacja aplikacji dla Windows -
dotnet publish -c Release -r linux-x64
- publikacja aplikacji dla Linux -
dotnet publish -c Release -r osx-x64
- publikacja aplikacji dla MacOS
dotnet add package StackExchange.Redis
ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
IDatabase db = redis.GetDatabase();
- Rejestracja
public void ConfigureServices(IServiceCollection services)
{
// dotnet add package StackExchange.Redis
services.AddSingleton<IConnectionMultiplexer>(ConnectionMultiplexer.Connect("localhost"));
}
- Uzycie
public class DbLocationRepository : ILocationRepository
{
private readonly IConnectionMultiplexer connection;
private readonly IDatabase db;
private const string key = "locations";
public RedisDbLocationRepository(IConnectionMultiplexer connection)
{
this.connection = connection;
this.db = connection.GetDatabase();
}
}