注:默认已经安装好docker。
为什么要离线安装?
其实离线安装是建立在在线安装的基础上的;因为有可能我们的服务器由于安全问题无法访问外网,自此我们需要将镜像手动上传至服务器中。
所以现在的场景就是:我们手上有一台笔记本,可以上网;笔记本上可以远程连接到我们的服务器,而服务器无法连接外网。
1、需要在本地拉取所需镜像,但拉取镜像需要相关docker环境,故先安装相应工具。
在windows上安装Docker Community Edition for windows的参考链接:
2、拉取所需镜像,并打成tar包
# 搜索有哪些镜像可以下载
docker search 镜像名
# 拉取镜像到本地
docker pull 镜像名
# 查看当前本机有哪些镜像
docker images
# 打包
docker save -o 要打镜像包名称 镜像
示例:docker save -o nginx.tar nginx # tar包的保存路径为当前路径
DockerHub官网:https://hub.docker.com/
3、使用ftp将打包好的tar包上传到服务器中
4、加载镜像进入服务器中的docker容器;
当然服务器中的docker也需要手动安装,该安装过程请参考
# 加载镜像;默认已经启动docker服务
docker load -i nginx.tar
5、查看镜像是否加载成功
docker image ls
6、进入相应文件夹创建yml文件(一般在app/nginx/docker-compose.yml文件夹下)
version: '3'
services:
nginx:
container_name: nginx
restart: always
image: nginx
ports:
- 8080:80
- 80:80
- 443:443
volumes:
- /data/nginx/conf.d:/etc/nginx/conf.d
- /data/nginx/log:/var/log/nginx
- /data/nginx/www:/var/www
- /etc/letsencrypt:/etc/letsencrypt
7、根据yml文件中的数据卷volume创建相应文件夹(但好像若不手动创建其实也会自动被创建,就像/etc/letsencrypt目录一样)
mkdir /data/nginx/conf.d # 不要以为有后缀就是文件,此处的conf.d仍是一个文件夹
mkdir /data/nginx/log
8mkdir /data/nginx/www
8、进入/data/nginx/conf.d目录下创建一个default.conf文件
server{
listen 80; # 监听80端口
server_name localhost; # 请求的域名
location / { # 当请求进来后,映射上 /
root /usr/share/nginx/html; # 将请求会映射到路径上.
index index.html; # 默认请求会去寻找index.html作为欢迎页面.
}
}
9、启动nginx服务
docker-compose -f yml文件所在路径 up -d
10、进入nginx容器
docker exec -it nginx bash
11、查看nginx容器中端口开放情况
netstat -tlpn
12、测试端口映射连通性
telnet 宿主机IP 8080 # 端口映射为8080:80 表示宿主机的8080端口对应到nginx容器的80端口
13、web页面验证nginx服务
# 网页中输入
宿主机IP:8080
自此,nginx在docker中已经安装成功!