docker部署php-fpm,nginx,mysql

mysql

1. 獲取mysql官方最新docker鏡像

docker pull mysql/mysql-server:latest

2. 查看下載的鏡像

docker images

3. 創(chuàng)建一個文件夾用戶掛載mysql數(shù)據(jù)庫文件

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: 后臺運行容器,并返回容器ID

--restart always: 在容器退出時重啟容器

-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. 查看容器啟動狀態(tài)

docker ps -a # 查看已創(chuàng)建的容器

docker ps -s # 查看已啟動的容器

若容器已創(chuà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)建一個文件夾用戶掛載nginx站點目錄以及配置文件

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. 查看容器啟動狀態(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共享站點目錄/data/www/htdocs

4. 查看容器啟動狀態(tài)

docker ps

優(yōu)化

固定ip

現(xiàn)有設(shè)置,每次重啟容器,該容器的ip地址就會更換,這就導(dǎo)致每次需要改nginx中配置的php-fpm的ip, 同時連接數(shù)據(jù)庫的ip也有同樣問題

1. docker默認(rèn)網(wǎng)絡(luò)

docker network ls

bridge:橋接網(wǎng)絡(luò)默認(rèn)情況下啟動的Docker容器,都是使用 bridge,Docker安裝時創(chuàng)建的橋接網(wǎng)絡(luò),每次Docker容器重啟時,會按照順序獲取對應(yīng)的IP地址,這個就導(dǎo)致重啟下,Docker的IP地址就變了

none:無指定網(wǎng)絡(luò)使用 --network=none ,docker 容器就不會分配局域網(wǎng)的IP

host: 主機(jī)網(wǎng)絡(luò)使用 --network=host,此時,Docker 容器的網(wǎng)絡(luò)會附屬在主機(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

# 此處注意,要先按照之前的方式啟動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,否則掛在的目錄會提示無權(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;

}

若配置證書,路徑必須是相對路徑,不支持絕對路徑

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)文章

centos7 docker部署

docker mysql 占內(nèi)存過多

推薦:?浮生無事的博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容