写在前面php
docker 容器编排可能更合适的是 Docker Compose 和 Kubernetes。平常开发,每每也不想要这么复杂,就丢一个容器里得了。mysql
建立镜像nginx
建立镜像有两种方式
1.从已经建立的容器中更新镜像
2.使用 Dockerfile 指令来建立一个新的镜像c++
这里咱们选用第一种方式,并选用 centos7 官方镜像做为初始镜像。web
拉取初始镜像(Centos7)sql
docker pull centos:7
启动容器docker
docker run -itd centos:7 /bin/bash
进入容器centos
docker exec -it ab3d851192b2 /bin/bash
开始安装软件浏览器
安装软件以前咱们先更新一下系统bash
yum update -y
安装一些经常使用的工具,下面用的着
yum -y install wget bzip2 gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel libxml2 libxml2-devel curl curl-devel
安装 ssh (服务端和客户端)
yum -y install passwd openssh-server openssh-clients
修改配置文件
vi /etc/ssh/sshd_config
找到 PermitRootLogin yes 把前面的注释符号 # 去掉,容许 root 用户登陆,由于是平常开发用,就用root吧,能够省不少事
为 root 用户设置一个密码
passwd root
测试一下服务能不能正常启动
/usr/sbin/sshd -D
哦,报错了
Could not load host key: /etc/ssh/ssh_host_rsa_key
Could not load host key: /etc/ssh/ssh_host_ecdsa_key
Could not load host key: /etc/ssh/ssh_host_ed25519_key
sshd: no hostkeys available -- exiting.
提示缺乏可用的 hotskeys,不要紧,建立它们
ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key
再试下,就能够了
安装 nginx
建立一个程序用户
useradd nginx
咱们用源码安装的方式,下载源码
cd /usr/local/src wget http://nginx.org/download/nginx-1.18.0.tar.gz tar -xvf nginx-1.18.0.tar.gz cd nginx-1.18.0 ./configure --prefix=/usr/local/nginx --with-http_ssl_module make && make install
修改环境变量
echo 'export PATH=/usr/local/nginx/sbin:$PATH' >> /etc/profile source /etc/profile
修改 nginx 配置
cd /usr/local/nginx/conf mkdir conf.d # 建立这个目录,用来放咱们的配置文件 vi nginx.conf
修改以下三处
user nginx; daemon off; include /usr/local/nginx/conf/conf.d/*.conf;
安装 php
cd /usr/local/src wget https://www.php.net/distributions/php-7.3.18.tar.bz2 tar -xvf php-7.3.18.tar.bz2 cd php-7.3.18 ./configure --prefix=/usr/local/php --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --enable-inline-optimization --enable-shared --enable-soap --enable-pdo --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-libzip --with-zlib --with-openssl --with-curl --enable-mbstring make && make install
修改环境变量
echo 'export PATH=/usr/local/php/bin:$PATH' >> /etc/profile source /etc/profile
修改 php 配置
cd /usr/local/php/etc cp php-fpm.conf.default php-fpm.conf vi php-fpm.conf # 找到下面这行,把前面的注释打开 pid = run/php-fpm.pid cd /usr/local/php/etc/php-fpm.d/ cp www.conf.default www.conf
安装 supervisor
直接用 yum 安装的方式
yum install -y epel-release yum install -y supervisor
修改配置文件
vi /etc/supervisord.conf # 以下几行注释打开,这了是为了做 web 的方式管理 supervisor,修改port为 port=0.0.0.0:9001 ,username 和 password 修改成你本身的 [inet_http_server] ; inet (TCP) server disabled by default port=0.0.0.0:9001 ; (ip_address:port specifier, *:port for all iface) username=user ; (default is no username (open server)) password=123 ; (default is no password (open server)) # 找到 nodaemon ,改成 true (由于 docker 自己就是个服务,里面不容许再说其余常驻服务,全部的应用同理) nodaemon=true
配置 sshd 启动服务
cd /etc/supervisord.d/ vi sshd.ini # 填加以下内容,保存就好 [program:sshd] command=/usr/sbin/sshd -D
配置nginx + fpm 启动服务
vi webserver.ini # 填加以下内容,保存 [program:nginx] command=/usr/local/nginx/sbin/nginx stopsignal=QUIT [program:php-fpm] command=/usr/local/php/sbin/php-fpm --nodaemonize stopsignal=QUIT
提交镜像
到这里咱们镜像就更新彻底了,咱们把这个容器做为镜像保存
docker commit -m="nginx+fpm" -a="actors315" ab3d851192b2 actors315/webdev:v1
docker images
会发现咱们的镜像已经建好了
使用镜像
docker run --name lingyin-dev -p 9001:9001 -p 2222:22 -p 80:80 -p 443:443 -v F:\www:/data/www -itd actors315/webdev:v1 /usr/bin/supervisord
查看一下效果
docker exec -it /bin/bash ps -ef|grep sshd ps -ef|grep nginx ps -ef|grep php-fpm
浏览器访问 http://127.0.0.1:9001/ 也能够看到服务都正常启动了
访问 http://127.0.0.1/ 熟悉的 nginx 欢迎页面。
到这里就大功告成了。
若是你想共享镜像,也能够提交到公共仓库
docker push actors315/webdev:v1