docker学习系列5 nginx 容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本节通过学习 docker 的 nginx 镜像,容器的使用。以及如何映射文件。运行容器docker run --name my-nginx -d -p 8088:80 --rm nginx:1.

本节通过学习 docker 的 nginx 镜像,容器的使用。以及如何映射文件。

  1. 运行容器
    docker run --name my-nginx -d -p 8088:80 --rm nginx:1.15
    -d:在后台运行
    -p :容器的80端口映射到 宿主机的 8088
    --rm:容器停止运行后,自动删除容器文件
    --name:容器的名字为 my-nginx
img_7870cd42f5e2b3eed9076813dcb5e8ec.png
image.png

docker run 其实等于 docker create + start
因为tag为 1.15 的 nginx 镜像并不在本地,会先下载再运行

浏览器打开 locahost:8088 就能看到默认页面了

  1. 官方推荐通过 Dockerfile 的方式制作镜像并运行容器

新建static-pages目录,结构如下:
static-pages
-- index.html
-- Dockerfile

index.html

<h1>Hello World</h1>

Dockerfile

FROM nginx:1.15
COPY . /usr/share/nginx/html

切换到Dockerfile所在路径

制作镜像 docker build -t my-nginx .,名称为 my-nginx,完整镜像名格式是:name:tag
参见 文档

img_da35bc251c6cd27161672686546b2c24.png
image.png

根据镜像运行一个容器
docker run --name my-nginx -d -p 8088:80 my-nginx:latest
浏览器打开 locahost:8088 就能看到 hello-world 了

3.如果要修改nginx配置文件,我们把容器里面的 Nginx 配置文件拷贝到本地的当前目录。
执行 docker container cp my-nginx:/etc/nginx .
不要漏掉最后那个点。执行完成后,当前目录应该多出一个nginx子目录。
修改Dockerfile

FROM nginx:1.15
COPY index.html /usr/share/nginx/html
COPY nginx /etc/

然后修改 static-pages\nginx\conf.d\default.conf

server {
    listen       80;
    server_name  ng.test;

C:\Windows\System32\drivers\etc\HOSTS
需要添加 127.0.0.10 ng.test 保持和localhost一致即可
重新制作镜像 docker build -t my-nginx:ng-test .
运行容器 docker run -d -p 80:80 my-nginx:ng-test 注意我映射的端口不再是8088,这样
本地浏览器就能访问 ng.test 了

停止容器:
先 docker ps 获取容器ID,比如是 934f93002018
然后 docker stop 934f93002018

相关文章
|
16天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
156 77
|
25天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
3天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
27 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
9天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
29 3
实战~如何组织一个多容器项目docker-compose
|
3天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
16 4
|
18天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
60 3
|
25天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
58 3
|
25天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
31 2
|
25天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
43 1
|
25天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
64 7