[Docker系列-2] 搭建nginx环境

简介:

1、获取Nginx容器端口

首先确保 docker 正在运行:

docker-machine ls  
AI 代码解读

1.1、启动进程

docker run -d -P --name web nginx  
AI 代码解读
  • docker run:启动一个容器
  • -d:后台运行容器
  • -P:开放容器的映射端口,方便你从Mac访问

1.2、查看容器状态

docker ps  
AI 代码解读
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                                           NAMES  
7afc79513310        nginx               "nginx -g 'daemon off"   10 hours ago        Up 5 seconds        0.0.0.0:32769->80/tcp, 0.0.0.0:32768->443/tcp   web  
AI 代码解读

可以看到已经启动nginx服务了

1.3、查看容器端口

docker port web  
AI 代码解读
443/tcp -> 0.0.0.0:32768  
80/tcp -> 0.0.0.0:32769  
AI 代码解读

可以看到容器的80端口映射到容器Docker主机的32769端口————监听主机上的32769端口相当于监听容器的80端口。

不过你现在访问http://localhost:32769你会发现找不到服务;

1.4、获取VM的IP

这是因为localhost 和 docker主机不一致,你需要获得VM的IP地址。

docker-machine ip default  #192.168.99.100  
AI 代码解读

现在在浏览器里打开http://192.168.99.100:32769就能看到熟悉的nginx界面了

那如何通过外面主机的公网IP查看效果呢?

STEP 1::查看主机IP

  ~  ifconfig | grep inet
    inet6 ::1 prefixlen 128
    inet 127.0.0.1 netmask 0xff000000
    inet6 fe80::1%lo0 prefixlen 64 scopeid 0x1
    inet6 fe80::62f8:1dff:fea9:bd98%en0 prefixlen 64 scopeid 0x4
    inet 10.2.87.112 netmask 0xfffff800 broadcast 10.2.87.255
    inet6 fe80::645a:84ff:fea9:1515%awdl0 prefixlen 64 scopeid 0x8
    inet 192.168.59.3 netmask 0xffffff00 broadcast 192.168.59.255
    inet 192.168.99.1 netmask 0xffffff00 broadcast 192.168.99.255
AI 代码解读

可以看到主机有两个IPv4的地址:一个是公网IP10.2.87.112,一个是192.168.59.3 。(请忽略192.168.99.1,因为还启用了另外一个虚拟机产生的)

我们希望能够通过 http://10.2.87.112:10000或者 http://192.168.59.3:10000能够访问到nginx的欢迎界面,直接打开是错误页面,需要进行端口映射操作。

STEP 2 : 设置端口映射

打开虚拟机设置界面,可以看到默认有一条设置了ssh的端口,是将主机的2022端口映射到虚拟机的22端口。为了将主机的10000端口映射到32769端口,我们添加一条映射规则,步骤如下:

设置端口映射

好了现在访问 http://10.2.87.112:10000或者 http://192.168.59.3:10000 就能看到熟悉的界面了。

参看文章:VMware NAT端口映射

1.5、关闭容器

最后关闭并移除容器的命令是

$ docker stop web
$ docker rm web
AI 代码解读

2、挂载文件夹

一旦开启 docker 之后,会自动共享/Users文件夹。 你可以将这个文件夹挂载到容器上。

2.1、创建示例文件夹及文件

$ cd $HOME
$ mkdir site
$ cd site
$ echo "my new site" > index.html
AI 代码解读

2.2、重启nginx服务并替换Html文件夹

$ docker run -d -P -v $HOME/site:/usr/share/nginx/html --name mysite nginx
$ docker port mysite
AI 代码解读
80/tcp -> 0.0.0.0:49166  
443/tcp -> 0.0.0.0:49165  
AI 代码解读

在浏览器里查看效果: 效果

2.3、实时更新内容

$HOME/site中添加新的文件:

$ echo "This is cool" > cool.html
AI 代码解读

新添加的文件

2.4、暂停并移除容器

$ docker stop mysite
$ docker rm mysite
AI 代码解读
玄农
+关注
目录
打赏
0
0
0
0
31
分享
相关文章
docker安装nginx,前端项目运行
通过上述步骤,你可以轻松地在Docker中部署Nginx并运行前端项目。这种方法不仅简化了部署流程,还确保了环境的一致性,提高了开发和运维的效率。确保按步骤操作,并根据项目的具体需求进行相应的配置调整。
47 25
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
104 3
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
464 1
基于Nginx和Consul构建自动发现的Docker服务架构——非常之详细
通过使用Nginx和Consul构建自动发现的Docker服务架构,可以显著提高服务的可用性、扩展性和管理效率。Consul实现了服务的自动注册与发现,而Nginx则通过动态配置实现了高效的反向代理与负载均衡。这种架构非常适合需要高可用性和弹性扩展的分布式系统。
51 4
基于Nginx和Consul构建自动发现的Docker服务架构——非常之详细
通过使用Nginx和Consul构建自动发现的Docker服务架构,可以显著提高服务的可用性、扩展性和管理效率。Consul实现了服务的自动注册与发现,而Nginx则通过动态配置实现了高效的反向代理与负载均衡。这种架构非常适合需要高可用性和弹性扩展的分布式系统。
69 3
Linux下搭建Nginx环境的搭建
Linux下搭建Nginx环境的搭建
94 6
SSH后判断当前服务器是云主机、物理机、虚拟机、docker环境
结合上述方法,您可以对当前环境进行较为准确的判断。重要的是理解每种环境的特征,并通过系统的响应进行综合分析。如果在Docker容器内,通常会有明显的环境标志和受限的资源视图;而在云主机或虚拟机上,虽然它们也可能是虚拟化的,但通常提供更接近物理机的体验,且可通过硬件标识来识别虚拟化平台。物理机则直接反映硬件真实信息,较少有虚拟化痕迹。通过这些线索,您应该能够定位到您所处的环境类型。
103 2
|
3月前
|
docker的底层原理二:容器运行时环境
本文深入探讨了Docker容器运行时环境的关键技术,包括命名空间、控制组、联合文件系统、容器运行时以及分离的进程树,这些技术共同确保了容器的隔离性、资源控制和可移植性。
58 5
windows系统配置nginx环境运行pbootcms访问首页直接404的问题
windows系统配置nginx环境运行pbootcms访问首页直接404的问题
|
3月前
|
docker nginx-proxy 添加自定义https网站
docker nginx-proxy 添加自定义https网站
56 4

热门文章

最新文章