mysql
1. 獲取mysql官方最新docker鏡像
docker pull mysql/mysql-server:latest
2. 查看下載的鏡像
docker images
3. 創(chuàng)建一個(gè)文件夾用戶掛載mysql數(shù)據(jù)庫(kù)文件
mkdir -p /data/docker/mysql/data
4. 生成mysql容器
docker run --name mysql -d --restart always -p 3306:3306 -v /data/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=q78b6513$de-ert --privileged=true mysql/mysql-server
--name mysql: 指定容器明后才能-d: 后臺(tái)運(yùn)行容器儒喊,并返回容器ID
--restart always: 在容器退出時(shí)重啟容器
-p 3306:3306: 將宿主機(jī)的3306端口(前者)映射到容器的3306端口(后者)
-v /data/docker/mysql/data: 將宿主機(jī)的目錄/data/docker/mysql/data映射到容器的目錄/var/lib/mysql
-e MYSQL_ROOT_PASSWORD: 設(shè)置初始密碼
5. 查看容器啟動(dòng)狀態(tài)
docker ps -a # 查看已創(chuàng)建的容器
docker ps -s # 查看已啟動(dòng)的容器
若容器已創(chuàng)建但未啟動(dòng)惑申,可通過(guò)以下命令啟動(dòng)
docker start mysql
6. 連接mysql
docker exec -it mysql bash # 進(jìn)入容器
mysql -uroot -p # 以之前設(shè)置的密碼登入mysql
alter USER 'root'@'localhost' identified with mysql_native_password by 'q67v5387$-ryhab'; # 設(shè)置root密碼
FLUSH PRIVILEGES; # 刷新
nginx
1. 獲取鏡像
docker pull nginx:latest
2. 查看下載的鏡像
docker images
3. 創(chuàng)建一個(gè)文件夾用戶掛載nginx站點(diǎn)目錄以及配置文件
mkdir -r /data/www/htdocs
mkdir -p /data/docker/nginx/conf.d
4. 生成nginx容器
docker run -d -p 80:80 -v /data/www/htdocs:/usr/share/nginx/html -v /data/docker/nginx/conf.d/:/etc/nginx/conf.d --name nginx --privileged=true nginx
5. 查看容器啟動(dòng)狀態(tài)
docker ps
php-fpm
1. 獲取鏡像
docker pull bitnami/php-fpm:latest
2. 查看下載的鏡像
docker images
3. 生成php-fpm容器
docker run -d -p 9000:9000 --name php-fpm -v /data/www/htdocs:/var/www/html --privileged=true bitnami/php-fpm
與nginx共享站點(diǎn)目錄/data/www/htdocs
4. 查看容器啟動(dòng)狀態(tài)
docker ps
優(yōu)化
固定ip
現(xiàn)有設(shè)置,每次重啟容器葫督,該容器的ip地址就會(huì)更換撒穷,這就導(dǎo)致每次需要改nginx中配置的php-fpm的ip, 同時(shí)連接數(shù)據(jù)庫(kù)的ip也有同樣問(wèn)題
1. docker默認(rèn)網(wǎng)絡(luò)
docker network ls
bridge:橋接網(wǎng)絡(luò)默認(rèn)情況下啟動(dòng)的Docker容器匣椰,都是使用 bridge,Docker安裝時(shí)創(chuàng)建的橋接網(wǎng)絡(luò)端礼,每次Docker容器重啟時(shí)禽笑,會(huì)按照順序獲取對(duì)應(yīng)的IP地址,這個(gè)就導(dǎo)致重啟下蛤奥,Docker的IP地址就變了
none:無(wú)指定網(wǎng)絡(luò)使用 --network=none 佳镜,docker 容器就不會(huì)分配局域網(wǎng)的IP
host: 主機(jī)網(wǎng)絡(luò)使用 --network=host,此時(shí)凡桥,Docker 容器的網(wǎng)絡(luò)會(huì)附屬在主機(jī)上蟀伸,兩者是互通的。
2. 創(chuàng)建自定義網(wǎng)絡(luò)
docker network create --subnet=172.18.0.0/16 mynetwork
3. 刪除原先創(chuàng)建的容器
docker stop mysql # 停止容器
docker stop nginx
docker stop php-fpm
docker ps -a # 查看創(chuàng)建的容器
docker rm {$ID} # 刪除創(chuàng)建的容器
4. 指定ip創(chuàng)建容器
docker run --net mynetwork --ip 172.18.0.2 --name mysql -d --restart always -p 3306:3306 -v /data/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=#q78b6513$de-ert --privileged=true mysql/mysql-server
docker run --net mynetwork --ip 172.18.0.3 --name nginx -d -p 443:443 -p 80:80 -v /data/www/htdocs:/usr/share/nginx/html -v /data/docker/nginx/conf.d/:/etc/nginx/conf.d -v /data/docker/nginx/ssl/:/etc/nginx/ssl -v /data/docker/nginx/log/:/var/log/nginx --privileged=true nginx
# 此處注意缅刽,要先按照之前的方式啟動(dòng)php-fpm容器,將其中的php-fpm.conf,www.conf拷貝到宿主機(jī)相應(yīng)位置
docker run --net mynetwork --ip 172.18.0.4 -d -p 9000:9000 -p 9001:9001 -p 9002:9002 --name php-fpm -v /data/www/htdocs:/var/www/html -v /data/docker/php-fpm/php-fpm.conf:/opt/bitnami/php/etc/php-fpm.conf -v /data/docker/php-fpm/fpm.d/:/opt/bitnami/php/etc/php-fpm.d -v /data/docker/php-fpm/fpm.d/www.conf:/opt/bitnami/php/etc/php-fpm.d/www.conf --privileged=true bitnami/php-fpm
ps:
一定要加上--privileged=true啊掏,否則掛在的目錄會(huì)提示無(wú)權(quán)限
要掛載的宿主機(jī)目錄一定要提前創(chuàng)建
mysql8 添加用戶
create user 'new_user'@'172.18.0.4' identified with mysql_native_password by 'q67v5387$-ryhab';
grant all privileges on test_db.* to 'new_user'@'172.18.0.4' with grant option;
flush privileges;
nginx配置
nginx一定要配置nginx容器內(nèi)的路徑root /user/share/nginx/html/
nginx連接php-fpm,一定要配置php容器內(nèi)的路徑
location ~ \.php$ {
????root /var/www/html/;
????fastcgi_pass 172.18.0.4:9000;#php容器的IP地址
????fastcgi_index index.php;
????fastcgi_split_path_info ^((?U).+\.php)(/?.+)$;
????fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
????fastcgi_param PATH_INFO $fastcgi_path_info;
????fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
}
若配置證書衰猛,路徑必須是相對(duì)路徑脖律,不支持絕對(duì)路徑
ssl_certificate? ?./ssl/server.pem;
ssl_certificate_key? ?./ssl/server.key;
ssl_session_timeout? ?5m;
ssl_protocols? ?SSLv2 SSLv3 TLSv1;
ssl_ciphers? ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
ssl_prefer_server_ciphers on;?
相關(guān)文章
推薦:?浮生無(wú)事的博客