在容器中部署静态网站----Nginx

在容器中部署静态网站----Nginx

步骤:

1.创建映射端口的交互式容器

docker run -p 80 --name web -i -t daocloud.io/ubuntu /bin/bash

2.安装Nginx

apt-get install -y nginx

3.安装文本编辑器vim

apt-get install -y vim

4.创建静态页面

mkdir -p /var/www/html
cd /var/www/html
vim index.html

使用i切换到插入模式

在index.html中写入以下内容:

<html>
<head>
<title>Nginx in Docker</title>
</head>
<body>Hello Docker</body>
</html>

保存退出

5.修改Nginx配置文件

vim /etc/nginx/sites-enabled/default

这样打开Nginx的配置文件之后会看见:

server {
        listen 80 default_server;
        listen [::]:80 default_server ipv6only=on;

        root /var/www/html;
        index index.html index.htm;

        # Make site accessible from http://localhost/
        server_name localhost;

        location / {
                # First attempt to serve request as file, then
                # as directory, then fall back to displaying a 404.
                try_files $uri $uri/ =404;
                # Uncomment to enable naxsi on this location
                # include /etc/nginx/naxsi.rules
        }

这个时候修改root的内容,修改成咱们html文件所在的位置.保存退出.

切换到根目录:

cd /

6.运行Nginx

nginx

可以使用ps -ef查看一下nginx是否运行了起来.

使用Ctrl+p+q可以将容器放在后台运行.

使用docker ps可以查看容器的运行效果.

也可以使用docker port web查看容器的端口映射:

80/tcp -> 0.0.0.0:32768

7.验证网站访问

curl http://127.0.0.1:32768

也可以在浏览器中访问这个页面:

http://127.0.0.1:32768

 

使用docker inspect web查看容器的ip地址:

    "NetworkSettings": {
        "Bridge": "docker0",
        "Gateway": "172.17.42.1",
        "GlobalIPv6Address": "",
        "GlobalIPv6PrefixLen": 0,
        "IPAddress": "172.17.0.1",
        "IPPrefixLen": 16,
        "IPv6Gateway": "",
        "LinkLocalIPv6Address": "fe80::42:acff:fe11:1",
        "LinkLocalIPv6PrefixLen": 64,
        "MacAddress": "02:42:ac:11:00:01",
        "PortMapping": null,
        "Ports": {
            "80/tcp": [
                {
                    "HostIp": "0.0.0.0",
                    "HostPort": "32768"
                }
            ]
        }
    },

可以看到"IPAddress": "172.17.0.1",这是容器的IP地址.

使用

curl http://127.17.0.1

就可以直接查看了.

也可以在浏览器中使用这个容器的IP地址.

最后需要说明一点,如果使用命令将容器停止:

docker stop web

然后开启容器:

docker start -i web

这个时候使用:

ps -ef

发现nginx是没有启动的.

使用Curl+p+q将容器放入后台.

使用:

docker exec web nginx

启动nginx服务.

使用:

curl http://172.17.0.1

发现不行了.

这个时候我们使用:

docker inspect web

看到以下输出结果:

    "NetworkSettings": {
        "Bridge": "docker0",
        "Gateway": "172.17.42.1",
        "GlobalIPv6Address": "",
        "GlobalIPv6PrefixLen": 0,
        "IPAddress": "172.17.0.2",
        "IPPrefixLen": 16,
        "IPv6Gateway": "",
        "LinkLocalIPv6Address": "fe80::42:acff:fe11:2",
        "LinkLocalIPv6PrefixLen": 64,
        "MacAddress": "02:42:ac:11:00:02",
        "PortMapping": null,
        "Ports": {
            "80/tcp": [
                {
                    "HostIp": "0.0.0.0",
                    "HostPort": "32769"
                }
            ]
        }
    },

发现容器的IP地和端口号都发生了变化,这个时候我们能知道,容器在重启之后的IP地址和端口号都会发生变化.

时间: 2024-10-10 21:13:30

在容器中部署静态网站----Nginx的相关文章

Docker 在容器中部署静态网站

Docker 在容器中部署静态网站 在容器中部署静态网站 设置容器的端口映射 run -P``--publish-all=true|false:容器暴露的所有端口进行映射 -p``--publish=[]:指定映射哪些容器端口 80:随机映射 8080:80:一一对应 0.0.0.0:80:指定IP 0.0.0.0:8080:80:IP 宿主机端口 容器端口 容器Nginx部署 创建映射80端口的交互式容器 安装Nginx 安装文本编辑器VIM 创建静态页面 修改Nginx配置文件 运行Ngin

在容器中部署静态网站(三)

设置容器的端口映射 通过run命令的两个选项来实现这个功能 run[-P][-p] -P(大写的P将为容器暴露的所有端口进行映射)(随机映射) -P,--publish-all=true|false默认为false dockerrun-P -i-tubuntu/bin/bash -p(小写的p能够指定映射容器哪些端口) -p,--publish=[] 指定端口有四种情况 containerPort docker run -p 80 -I -tubuntu /bin/bash hostPort:c

【Docker】练习-在容器中部署静态网站

创建映射80端口的交互式容器 安装Nginx 安装文本编辑器vim 创建静态页面 修改Nginx配置文件 运行Nginx 验证网页访问 1.运行一个待端口映射的交互容器,命名为web docker run -p 80 --name web -i -t ubuntu /bin/bash 2.进入容器, 安装Nginx apt-get install -y nginx 3.(可选)发现运行结果为unable to locate package nginx,需要执行如下命令 apt-get updat

Docker学习笔记(4-3)Docker容器内部署静态网站

设置容器的端口映射 如何访问容器的80端口<--设置端口映射 -P 为所有端口映射 -p 指定映射端口 docker run -p 80 -i -t ubuntu /bin/bash docker run -p 8080:80 -i -t ubuntu /bin/bash docker run -p 0.0.0.0:80 -i -t ubuntu /bin/bash docker run -p 0.0.0.0:8080:80 -i -t ubuntu /bin/bash #创建映射80端口的交互

在Docker容器中部署静态网页的方法教程

步骤:1.创建映射端口的交互式容器docker run -p 80 --name web -i -t daocloud.io/ubuntu /bin/bash2.安装Nginxapt-get install -y nginx 3.安装文本编辑器vimapt-get install -y vim4.创建静态页面 mkdir -p /var/www/html cd /var/www/html vim index.html 使用i切换到插入模式 在index.html中写入以下内容: <html>

Windows10系统下在Docker中部署静态网站

1.关于docker的安装和docker命令这里不写.可以查看我上一篇文章. 准备dockerfile文件和 index.html .   假设文件在c:/mufolder/目录 1. Dockerfile 内容如下: #Dockerfile FROM httpd #copy 命令,将./myfolder/ 目录文件全部copy到 docker里htdocs目录. 这里我不用. #COPY ./myfolder/ /usr/local/apache2/htdocs/ WORKDIR /usr/l

Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)--技术流ken

前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+Ansible剧本实现一键部署动态网站(二)--技术流ken>,以及关于jenkins的简单使用<Jenkins持续集成介绍及插件安装版本更新演示(一)--技术流ken>.相信大家也已经完全掌握了这三项工具的使用,也可以使用这几项工具可以部署静态以及动态网站了. 以前的博客可以实现一键部署网站

docker 学习(九) docker部署静态网站

原文:docker 学习(九) docker部署静态网站 一:  dockerfile, 把Dockerfile和myfolder放在一个目录下: FROM httpd:2.4 COPY ./myfolder/ /usr/local/apache2/htdocs/ WORKDIR /usr/local/apache2/ RUN chown -R daemon:daemon htdocs && chmod -R 755 htdocs 二: 生成镜像: docker build -t   im

在Docker容器中部署Web应用

本文直接讲解如何在Docker容器中实战部署一个Web应用程序,关于Docker相关的概念和如何安装Docker请参考相关资料完成. 第一步:工具准备 演示如何在Docker容器中部署一个Java Web应用程序,需要准备的软件工具包括:jre,tomcat和webapp应用.另外,为了实现在容器启动时自动启动webapp,需要编写一个脚本工具完成该工作. 安装jre,请参考:http://www.wikihow.com/Install-Java-on-Linux 安装tomcat,请参考:ht