Komendy Linux i Docker: referencja i rozwiązywanie problemów

Opublikowaliśmy te komendy dla naszych deweloperów w celach referencyjnych. Są one publicznie widoczne, ponieważ mogą być przydatne także dla innych deweloperów:

Docker

#zatrzymaj wszystkie kontenery: docker stop $(docker ps -a -q)

Zrestartuj usługę Docker

sudo systemctl restart docker.service Odtwórz wszystkie kontenery docker-compose up --build --force-recreate --no-deps #zatrzymaj wszystkie kontenery siłowo docker kill $(docker ps -q) #usuń wszystkie kontenery docker rm $(docker ps -a -q) #usuń wszystkie obrazy Dockera docker rmi $(docker images -q) #wyczyść resztę docker system prune --all --force --volumes #Znajdź IP kontenera docker inspect -f '{{range.NetworkSettings.Networks}}{{.IPAddress}}{{end}}' [container_name] #Pokaż logi Dockera docker-compose logs #Pokaż procesy Dockera docker-compose ps Uruchom mysqldump w kontenerze docker exec [container_name] sh -c 'exec mysqldump --all-databases -uroot -p[password]' > /home/user/all-databases.sql Komunikat błędu: Could not kill running container runc did not terminate successfully: container_linux.go:392: init process caused „permission denied” Może się to zdarzyć, jeśli apparmor uniemożliwia zatrzymanie kontenera Docker. Jednym z rozwiązań jest odinstalowanie apparmor i zrestartowanie usługi Docker: sudo apt-get purge --auto-remove apparmor sudo service docker restart docker system prune --all --volumes sudo systemctl restart docker sudo systemctl daemon-reload Błąd uruchamiania userland proxy: listen tcp 172.200.0.1:443: bind: address already in use Znajdź PID i go zabij: sudo netstat -nlpt |grep 3306 sudo kill [pid]

Sieć

Liczba otwartych połączeń na IP netstat -ntu | awk '{print $5}’ | cut -d: -f1 | sort | uniq -c | sort -n Pokaż wszystkie adresy IP połączone z danym portem netstat -an |grep 443 netstat -an |grep 80 Policz połączenia na IP netstat -an | grep 80 | wc -l netstat -an | grep 443 | wc -l

Firewall iptables

Firewall: zablokuj adres IPsudo iptables -A INPUT -s [IP ADDRESS] -j DROP Zezwól na dostęp z konkretnego adresu IPsudo iptables -A INPUT -s 91.52.78.249 -p tcp –destination-port 3306 -j ACCEPT Odblokuj adresy IP zablokowane przez fail2ban iptables -D [chain] [line] z.B. iptables -D f2b-wordpress-hard 1 Reguły firewalla Zobacz: https://www.digitalocean.com/community/tutorials/how-to-set-up-a-firewall-with-ufw-on-ubuntu-18-04

  • sudo ufw default deny incoming
  • sudo ufw default allow outgoing
  • sudo ufw allow ssh
  • sudo ufw allow 1000
  • sudo ufw allow http
  • sudo ufw allow 443
  • sudo ufw allow from 91.52.78.249 to any port 3306 (Lokalny adres IP)
  • sudo ufw allow from 52.45.200.92 to any port 3306 (Amazon DBS)
  • sudo ufw deny from 157.245.247.135

MySQL

Zmień moduł uwierzytelniania haseł MySQL na mysql_native_password. Wymagane przy aktualizacji z 7.X do MySQL 8.x ALTER USER 'user’@’localhost’ IDENTIFIED WITH mysql_native_password BY 'password1′;

Debugowanie xDebug:-)

Jeśli Twój edytor kodu nie łączy się z xDebugiem, utwórz plik test.php w folderze aplikacji z jakimś kodem i ustaw na nim breakpoint. Następnie uruchom poniższą komendę, aby to przetestować:

PHP_IDE_CONFIG="serverName=tests" php -dxdebug.remote_autostart=1 -dxdebug.remote_enable=1 -dxdebug.default_enable=1 -dxdebug.remote_connect_back=1 -dxdebug.remote_port=9001 -dxdebug.idekey=PHPSTORM -dxdebug.remote_host=172.200.0.1 test.php

Logowanie przeładowuje ekran logowania

Jeśli próbujesz zalogować się do KDE, a formularz logowania przeładowuje się po wprowadzeniu poprawnych danych logowania, wypróbuj poniższe komendy:

systemctl stop gdm.service
systemctl restart gdm.service
sudo dpkg-reconfigure gdm3
reboot
Rene Hermenau

Autor: Rene Hermenau

O autorze: René Hermenau jest założycielem WP STAGING. Zajmuje się kopiami zapasowymi WordPressa, środowiskami stagingowymi, migracjami, obsługą baz danych oraz bezpiecznymi procesami wdrażania.