查看环境
cat /etc/redhat-release
// CentOS Linux release 7.6.1810 (Core)
安装所需软件包
$ sudo yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
设置稳定的存储库
$ sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
安装 docker CE
$ sudo yum install docker-ce docker-ce-cli containerd.io
启动 docker
// 启动 docker 服务
$ sudo systemctl start docker
or
$ sudo systemctl start docker.service
// 设置docker 自启动
$ sudo systemctl enable docker.service
// 关闭 docker 服务
$ sudo systemctl stop docker.service
// 查看 docker 服务状态
$ sudo systemctl status docker.service
运行 hello world
$ sudo docker run hello-world
docker 常用指令
-i:容器的标准输入保持打开
-t:让docker分配一个伪终端并绑定到容器的标准输入上
-p : 端口映射 格式为[主机端口:容器端口]
-d : 后台模式运行
-name : 给容器的起一个名字
-v:挂载主机的目录
#删除指定名称镜像
docker rmi hello-world
#删除所有镜像
docker rmi -f $(docker images)
// 不指定网络驱动时默认创建的bridge网络
docker network create default_network
// 查看网络内部信息
docker network inspect default_network
// 列所有列表的网络
docker network ls
// 移除指定的网络
docker network rm default_network
从 docker hub 下载 mongodb 官方镜像
docker pull mongo
创建 mongodb 容器
docker run --name my-mongo -p 27017:27017 -d mongo --auth
// 如果加需要验证就加--auth,不需要验证,就去掉。默认mongodb是不使用用户认证
查看 mongo 的容器 id
docker ps -a
进入容器设置用户
// 逐行执行
docker exec -it 容器id /bin/bash
mongo
use admin
db.createUser({user:"root",pwd:"root",roles:[{role:'root',db:'admin'}]})
exit
创建成功,后续操作都需要用户认证
Successfully added user: {
"user" : "root",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}
测试 mongo
mongo 宿主机ip/admin -utest -p
指定 mongodb 配置文件
docker run --name some-mongo -d mongo --configsvr
使用 navicat 连接数据库
启动 docker 服务
systemctl start docker
拉取 node 镜像
docker pull node
确认下 node 是否拉取成功
docker images
OK
启动镜像
docker run -i -t node /bin/bash
将 docker 的 3000 端口映射到 tcp 的 3000 并分配给 node
docker run --name node-app -idt -p 3000:3000 node /bin/bash
映射本地目录到 docker
docker run -it -p 3000:3000 -v /home/unishop:/home/unishop --privileged=true node /bin/bash
docker run -it -d -p 3000:3000 -p 3001:3001 -v /home/code:/home/code --privileged=true --name node node /bin/bash
docker run --name node --network main-net -it -d -p 3000:4000 -v /home/node:/home/node --privileged=true node /bin/bash
查看 node 版本号
node -v
// v12.11.1
安装 pm2
npm i pm2 -g
// + pm2@4.0.0
查找 nginx 镜像
docker search nginx
拉取官方镜像
$ docker pull nginx
nginx 常用指令
// 启动 nginx 容器
docker run -d --name nginx nginx
// 查看 nginx 实例进程
docker top nginx
// 进入 nginx 容器
docker exec -it nginx bash
// 杀死 nginx 容器实例
docker kill -s KILL
// 重启 nginx 容器实例
docker restart nginx
// 移除 nginx 容器实例
docker rm -f -v 容器id
基于 docker run -d --name nginx nginx 方法启动 nginx 后,docker 容器并没有对外暴露访问 nginx 的端口,即无法通过当前主机外部浏览器器访问 nginx。使用如下命令来指定 docker 容器中 nginx 实例对外开放的端口
docker run --name nginx -d -p 80:80 nginx
第一个80端口是对外开放的端口,第二个80端口指对外开放的端口映射到容器里的端口号
然而报错
docker: Error response from daemon: Conflict. The container name "/nginx" is already in use by container "22e8e4970c9e1567b4c5d9070eb83ec81f1cd3c9b7bb274979ed47ccd1903a51". You have to remove (or rename) that container to be able to reuse that name.
需要移除 nginx 并重新创建
docker rm -f -v 容器id
// 22e8e4970c9e
docker run --name nginx -d -p 80:80 nginx
// e72059387cdcf2d6deb740ecb4ee467120322fd29bcc26b9c3c2b339b54d5b57
测试 nginx