Docker 的安装过程十分的简单:
Debian、Ubuntu 等操作系统:
mkdir ~/docker && cd ~/docker && sudo apt-get -y install docker.io
CentOS 等操作系统:
yum install -y yum-utils device-mapper-persistent-data lvm2 && yum-config-manager --add-repo https://mirrors.cloud.tencent.com/docker-ce/linux/centos/docker-ce.repo && yum install -y docker-ce docker-ce-cli containerd.io
注意:apt-get 命令适用于 deb 包管理式的 Linux 操作系统(Debian、Ubuntu等), CentOS请使用 yum 命令
执行docker 并查看状态
systemctl start docker && service docker status
完成后,您可以通过
docker version
来查看 Docker 的版本信息,
docker help
来查看 Docker 的帮助文档。
Docker 工作的基础即是镜像。您可以认为一个镜像即是一个独立的由应用组成的虚拟机。为此,docker 建立了 Docker Hub 来存贮镜像(就像GitHub一样)。
但是由于网络原因, Docker Hub 的访问速度过慢,推荐您更换为国内的镜像源地址。这里我们采用 腾讯云 Docker 镜像加速,请输入下面的命令:
sudo su -
cat >> /etc/docker/daemon.json <<- EOF
{
"registry-mirrors": ["https://mirror.ccs.tencentyun.com"]
}
EOF
systemctl restart docker
exit
Docker 使用docker pull <镜像>
来完成镜像的下载工作,而我们本次实验需要使用到的镜像有。
docker image ls
来查看已下载的镜像。运行以下命令:
sudo docker pull nginx:alpine
运行以下命令:
sudo docker pull php:7-fpm-alpine
您可能注意到了,我们使用 PostgreSQL 代替了 MySQL 。两者在使用上的差异并不大,但是从大小上看, PostgreSQL 更适合于容器化,因此我们选择了它。
可观看视频了解 PostgreSQL介绍
运行以下命令:
sudo docker pull postgres:alpine
本节的目的是为了让您尝试使用docker run
来启动容器(启动后的镜像即为容器)。此处只介绍其主要用法。
您可以使用以下命令来启动容器:
sudo docker run --rm -d -p 80:80 --name nginx nginx:alpine
--rm
:表示这个容器执行完后会被直接销毁(docker stop nginx之后,该容器被销毁)。--name
:指定这个容器的名称。-d
:表示这个容器会在后台运行。-p
:表示开放容器的80端口到主机的80端口。-v
:表示将nginx的配置文件挂载到容器的对应目录下。完成后您应该可以在对应的网址(http://175.178.122.115/,此处为服务器的IP地址
)上看到 Nginx 的默认欢迎界面了。
您可以使用以下命令来停止一个容器:
sudo docker stop <容器ID或容器名称>
容器ID就是您在运行上面那个命令时显示的一串字符,或者您可以使用
sudo docker container ls
来查看所有容器及其ID。
对于使用容器ID停止容器,您可以只输入前几个字符,Docker会自动匹配剩下的字符。
但是对于使用容器名称停止容器,您必须完整地输入容器名称。
例如:sudo docker stop 91b6
请尝试停止Nginx:
sudo docker stop nginx
docker run -d -p 8080:80 --name nginx_demo nginx
mkdir -p /data/nginx1/{conf,html}
docker cp nginx_demo:/usr/share/nginx/html /data/nginx1
docker cp nginx_demo:/etc/nginx/nginx.conf /data/nginx1/conf/nginx.conf
docker cp nginx_demo:/etc/nginx/conf.d/default.conf /data/nginx1/conf/default.conf
docker cp nginx_demo:/var/log/nginx /data/nginx1
mv /data/nginx1/nginx /data/nginx1/logs //更改文件夹的名字,此处根据个人习惯,只要后面的挂载路径相匹配就行
docker run -d -p 80:80 \
-v /data/nginx1/html:/usr/share/nginx/html \
-v /data/nginx1/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /data/nginx1/conf/default.conf:/etc/nginx/conf.d/default.conf \
-v /data/nginx1/logs:/var/log/nginx \
--name nginx_test1 nginx
此时,就可以直接在宿主机的 /data/nginx1目录下,修改ngnix_test1 容器的nginx配置信息。
可以启动
n
个nginx容器,命名nginx_testn ,并在宿主机的 /data/nginxn目录下存放相应容器的配置信息。
映射的端口不能重复
,否则创建失败
1、启动一个草稿 php (因为要去复制一些默认配置文件,如果有可省略)
docker run --rm --name php-test -p 9000:9000 -d php:7-fpm-alpine
2、创建存放 php 配置文件和日志的目录
mkdir /data/php/{conf,logs}
3、复制容器内的默认配置文件 #我只复制了这一份
docker cp php-test:/usr/local/etc/php/php.ini-production /data/php/conf/php.ini
4、创建 php 正式使用的容器
docker run -p 9000:9000 --name php \
-v /data/php7/conf:/usr/local/etc/php \
-v /data/php7/logs:/phplogs \
-v /data/nginx1/html:/usr/share/nginx/html \
-d php:7-fpm-alpine
-v /data/nginx1/html:/usr/share/nginx/html 这个配置一定要与Nginx的项目路径一致,否则会报 File Not Found 错误❌
5、注意:最大的坑就是上面的 File Not Found! Nginx明明访问 index.html(静态资源) 正常,访问不了 index.php。php 默认访问的 ip 不再是 127.0.0.1:9000 了!!!
docker inspect php
找到这个 IPAddress 的值,填入 nginx 的配置配件 default.conf
"IPAddress": "172.17.0.2"
location ~ \.php$ {
root /usr/share/nginx/html;
fastcgi_pass 172.17.0.2:9000;#这里的值改成之前查到的
#fastcgi_pass php:9000;#或者容器名:9000 我好像没成功,应该是没配置网络组的问题
fastcgi_index index.php;
#fastcgi_param SCRIPT_FILENAME /usr/share/nginx/html$fastcgi_script_name;#这里用绝对路径
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;#或者用$document_root变量
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
include fastcgi_params;
}
然后重启 nginx
docker restart nginx
由于 LNMP 共由3个容器组成,单个启动过于麻烦,推荐您使用 docker-compose
管理并启动它们。
docker-compose 是 Docker 的多个服务部署工具,以方便地同时启动多个容器。
您可以使用以下命令方便地安装它。
sudo apt-get install -y python-pip && sudo pip install docker-compose
对于每一个您希望使用 docker-compose
来启动的项目,您都应该在 该项目的目录下
配置 docker-compose.yml
创建docker-compose.yml文件
touch ~/docker/docker-compose.yml
点击打开 docker-compose.yml
文件进行编辑,参考内容如下:
##docker-compose.yml
version: "3"
services:
Nginx:
image: nginx:alpine
ports:
- 80:80
volumes:
- ./web:/usr/share/nginx/html:ro
- ./nginx.conf:/etc/nginx/conf.d/default.conf:ro
PHP:
image: undefined01/php:7-fpm-alpine
volumes:
- ./web:/var/www/html:rw
Database:
image: postgres:alpine
environment:
POSTGRES_USER: "postgres"
POSTGRES_PASSWORD: "rootroot"
volumes:
- ./data:/var/lib/postgresql/data:rw
记得保存!
保存方法:Windows 系统点击 ctrl+s
,Mac OS 点击 command+s
保存
version
:表示这个配置文件使用第三套标准。services
:表示需要启动的服务(容器)列表。image
:表示该服务使用的镜像。ports
:表示该服务开放的端口。volumes
:表示将某目录或文件挂载到容器的相应位置上,后面的ro、rw表示对于容器是否可读写。此处挂载了配置文件、数据库和网站代码。enviornment
:设置该容器的环境变量。此处通过环境变量的形式设置数据库的账号和密码。创建nginx.conf文件
touch ~/docker/nginx.conf
为了让 Nginx 能够将请求顺利的转交给 PHP 处理,我们需要更改 Nginx 的配置文件。
点击打开 nginx.conf 文件进行编辑,参考内容如下:
##nginx.conf
server {
listen 80;
server_name localhost;
location / {
root /usr/share/nginx/html;
index index.php index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
location ~ \.php$ {
fastcgi_pass PHP:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/html/$fastcgi_script_name;
include fastcgi_params;
}
}
如何更改容器里的配置文件?
很简单,我们只需要在本地编辑好后挂载到容器中去(会覆盖容器中的文件),前面小节中预留的nginx.conf
就是为此。
如何让 Nginx 容器与 PHP 容器通讯?
您可能注意到了下面提供参考的 nginx.conf
里用到了PHP:9000
这样的地址。没错,对于由 docker-compose 启动的所有容器,都会自动加入由 docker 维护的局域网中,并且会自动为其他容器将某容器的名称(如 PHP )解析成相应的局域网IP。
使用以下命令来启动服务:
sudo docker-compose up -d
可以使用以下命令来查看启动服务:
sudo docker container ls
以上命令都使用了root
权限,因此您如果想要修改其中的内容可能不太方便。您可以使用以下命令来获取编辑权限。
sudo chmod -R 777 ./data ./web
touch ~/docker/web/index.php
点击打开 web/index.php
进行编辑, 参考内容如下:
## index.php
<?php
phpinfo();
?>
如果一切顺利的话,您就可以在http://175.178.122.115/index.php (此处为服务器的IP地址
)看到 php 的相关信息了。
您还记得密码吗?就在 docker-compose
中配置了。因此在实际环境中您一定要注意该文件的访问权限。
至于 PostgreSQL 数据库的地址嘛,就是这个容器的名称(此处是 Database )。您可以把它想象为一个域名就好了。
创建test.php文件
touch ~/docker/web/test.php
点击打开 web/test.php
进行编辑, 参考内容如下:
##test.php
<?php
$dbconn = pg_connect('host=Database user=postgres password=rootroot') or die('Could not connect: ' . pg_last_error());
pg_query('CREATE TABLE IF NOT EXISTS test ( tester INT )');
pg_query('INSERT INTO test VALUES (0)');
$res = pg_query('SELECT * FROM test') or die('Query failed: ' . pg_last_error());
$num = pg_num_rows($res);
echo "You have visited this site $num times";
pg_free_result($res);
pg_close($dbconn);
?>
如果一切顺利的话,您就可以在http://175.178.122.115/test.php (此处为服务器的IP地址
)看到一个网页计数器。
不断刷新它试试看。
您可以使用以下命令来停止服务,它会自动销毁相应的容器:
sudo docker-compose down
用命令查看 docker 目录:
ls -la ~/docker
您的数据库已经保存在当前 docker
目录下的 data
文件夹中了,用命令查看:
ls -lf ./data
什么?销毁?别担心,迁移到任何一台新的主机,只需要将该目录打包带走就行了!
不信?您可以重新启动上面的示例,刷新 test.php 这个计数网页, 看看数据库是否被保存了下来。