将Docker中nginx静态资源目录映射到宿主机的某个目录及配置文件映射到宿主机

在Docker中运行Nginx时,可以通过-v或--volume参数将Nginx容器内的静态资源目录映射到宿主机的某个目录。这样,你就可以在宿主机上直接管理和修改这些静态资源,而无需进入容器内部。以下是具体的操作步骤:

一、准备宿主机目录

首先,在宿主机上创建一个目录,用于存放Nginx的静态资源。例如,可以创建一个名为nginx-static的目录:

mkdir -p /path/to/nginx-static

其中,/path/to/是自定义的路径,你可以根据实际情况进行调整。

二、启动Nginx容器并映射静态资源目录

使用docker run命令启动一个新的Nginx容器,并通过-v参数将宿主机上的nginx-static目录映射到容器内的静态资源目录(通常是/usr/share/nginx/html)。命令如下:

docker run -d -p 8002:80 --name my-nginx \
-v /path/to/nginx-static:/usr/share/nginx/html \
nginx:1.12.2

这条命令做了以下几件事情:

  • -d:以守护进程模式运行容器。
  • -p 8002:80:将宿主机的8002端口映射到容器的80端口,以便通过浏览器访问Nginx服务。
  • --name my-nginx:为容器指定一个名称(my-nginx),方便后续管理。
  • -v /path/to/nginx-static:/usr/share/nginx/html:将宿主机上的nginx-static目录映射到容器内的/usr/share/nginx/html目录,这是Nginx默认的静态资源目录。

三、验证映射是否成功

启动容器后,你可以在宿主机上的nginx-static目录中放置一些静态资源(如HTML、CSS、JavaScript文件等)。然后,通过浏览器访问宿主机的IP地址或域名(如果配置了DNS解析),你应该能够看到这些静态资源被Nginx成功提供。

四、注意事项

确保宿主机上的nginx-static目录具有正确的权限和所有权,以便Nginx容器能够访问其中的文件。

如果Nginx容器已经运行,并且你想要将静态资源目录映射到另一个宿主机目录,你需要先停止并删除现有的容器,然后按照上述步骤重新创建一个新的容器。

如果你想在容器内修改Nginx的配置文件(如nginx.conf),你也可以通过类似的方式将配置文件映射到宿主机的某个目录,并在该目录中编辑配置文件。然后,通过重启Nginx容器或重新加载Nginx配置来使更改生效。

通过以上步骤,你就可以将Docker中Nginx的静态资源目录映射到宿主机的某个目录,并在宿主机上直接管理和修改这些资源了。

五、将Docker中nginx静态资源目录映射到宿主机的某个目录及配置文件映射到宿主机:

docker run -d -p 8003:80 --name my-nginx -v /home/sam/nginx:/usr/share/nginx/html -v /home/sam/conf/nginx.conf:/etc/nginx/nginx.conf nginx:1.12.2

修改映射后的配置文件后记得重启docker服务,比如设置301跳转,以nginx 1.12.2为例,nginx.conf修改如下:

    server {listen 80;server_name yourdomain.com;  # 替换为你的域名# 其他配置...# 实现特定路径的301重定向location /abc {return 301  http://www.xxxxxxxxxx.com;}location / {# 默认配置,例如代理传递、静态文件服务等# 例如,如果你想让 Nginx 返回一个简单的 "Hello, World!" 页面,可以这样配置:root /usr/share/nginx/html;index index.html;}# 其他 location 块配置...}
user  nginx;
worker_processes  1;error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;events {worker_connections  1024;
}http {include       /etc/nginx/mime.types;default_type  application/octet-stream;log_format  main  '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" ''"$http_user_agent" "$http_x_forwarded_for"';access_log  /var/log/nginx/access.log  main;sendfile        on;#tcp_nopush     on;keepalive_timeout  65;#gzip  on;server {listen 80;server_name yourdomain.com;  # 替换为你的域名# 其他配置...# 实现特定路径的301重定向location /abc {return 301  http://www.xxxxxxxxxx.com;}location / {# 默认配置,例如代理传递、静态文件服务等# 例如,如果你想让 Nginx 返回一个简单的 "Hello, World!" 页面,可以这样配置:root /usr/share/nginx/html;index index.html;}# 其他 location 块配置...}include /etc/nginx/conf.d/*.conf;
}

注意以上配置内容。

重启docker中nginx:

[root@localhost home]# docker ps
CONTAINER ID   IMAGE                       COMMAND                   CREATED          STATUS             PORTS                                            NAMES
22183dc1c4ce   nginx:1.12.2                "nginx -g 'daemon of…"   43 minutes ago   Up 3 minutes       0.0.0.0:8001->80/tcp, :::8001->80/tcp            my-nginx-v
[root@localhost home]# docker restart my-nginx-v
my-nginx-v

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/15011.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

api驱动的云服务是什么意思?

API驱动的云服务是指利用API技术来驱动和提供云服务的模式。在这种模式下,云服务提供商会公开一系列的API接口,允许开发者或应用程序通过调用这些API来实现对云服务的访问和操作。API驱动的云服务是现代云计算技术的重要组成部分,API驱动的云…

Springboot 启动端口占用如何解决

Springboot 启动端口占用如何解决 1、报错信息如下 *************************** APPLICATION FAILED TO START ***************************Description:Web server failed to start. Port 9010 was already in use.Action:Identify and stop the process thats listening o…

【Rust调用Windows API】杀掉指定进程(包括兄弟进程、子进程、父进程)

前言 前面一篇文章写了使用Rust调用Windows API 获取正在运行的全部进程信息 ,本篇实现杀掉指定进程。 通过标准库可以管理当前进程创建的子进程,要 kill 掉子进程也比较容易,这里不赘述了,主要实现通过调用Windows API来杀掉兄…

基于Python的外卖点餐系统

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…

世界坐标系、相机坐标系、图像物理坐标系、像素平面坐标系

坐标系及其转换在计算机视觉领域占据核心地位。理解如何从一个坐标系转换到另一个坐标系,不仅是理论上的需要,也是实际应用中不可或缺的技能。 一、世界坐标系的定义 世界坐标系是一个全局的坐标系统,用于定义场景中物体的位置。在这个坐标…

Pycharm也可以用来查看和操作MySQL数据库?

1.首先确保自己的电脑安装好MySQL MySQL :: Download MySQL Community Server 2.在创建project界面选择Open 打开并选择自己存放sql文件的路径 完成后的效果 3.创建好数据库的连接 4.打开Database视窗 5.给数据库添加新的Schema 6.运行需要查看或者操作的sql文件 7.选择适合的…

1、VMware12安装ubuntu18.04

1、ubuntu18地址获取: Index of /ubuntu-releases/18.04/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 2、安装过程: 1、新建虚拟机 2、选择稍后安装操作系统 3.客户机操作系统选择Linux,版本选择Ubuntu 64位 4、点击“自定义…

数据结构查找-哈希表(创建+查找+删除)+(C语言代码)

#include<stdlib.h> #include<stdio.h> #include<stdbool.h> #define NULLKEY -1//单元为空 #define DELKEY -2//单元内容被删除 #define M 20 typedef struct {int key;//关键字int count;//统计哈希冲突探测次数 }HashTable; //插入到哈希表 void InsertHT…

基于Java的周次生成工具类实现

摘要&#xff1a; 本文介绍了一个基于Java的周次生成工具&#xff0c;用于根据指定的年份和周次类型&#xff08;自然周或财务周&#xff09;生成连续的周次列表数据。 需求描述&#xff1a; 根据周次类型&#xff0c;生成连续的周次列表数据。 周次类型分2种&#xff1a; …

为什么华大严选基因是您的最佳选择?品牌特色全解析

《为什么华大严选基因是您的最佳选择&#xff1f;品牌特色全解析》 在当今基因检测市场竞争激烈的环境下&#xff0c;华大严选基因以其卓越的品质和独特的品牌特色脱颖而出&#xff0c;成为众多消费者的首选。作为 DNA 基因检测行业十佳优质品牌和 3・15 重点推荐品牌&#xff…

中仕公考怎么样?国考有三不限岗位吗?

国考有三不限岗位吗? “三不限”岗位&#xff0c;即不限制专业、学历和户籍的岗位。国考中几乎没有“三不限”岗位。因为公务员国考的报考条件通常较为严格&#xff0c;尤其是不限制条件的职位更少见&#xff0c;所以国考中一般是没有三不限岗位的。 与省考公务员不同的是&a…

Day44 | 动态规划 :状态机DP 买卖股票的最佳时机IV买卖股票的最佳时机III

Day44 | 动态规划 &#xff1a;状态机DP 买卖股票的最佳时机IV&&买卖股票的最佳时机III&&309.买卖股票的最佳时机含冷冻期 动态规划应该如何学习&#xff1f;-CSDN博客 本次题解参考自灵神的做法&#xff0c;大家也多多支持灵神的题解 买卖股票的最佳时机【…

inode,请别忽视它!

在Linux文件系统中&#xff0c;inode 是一个不可忽视的核心概念。它不仅是文件系统运行的基石&#xff0c;还在内核、应用程序以及驱动程序开发中扮演着重要角色。如果你曾对文件的底层运作感到困惑&#xff0c;或者在面试中遇到文件系统相关问题&#xff0c;那么理解inode绝对…

x-cmd pkg | howdoi - 无需打开浏览器,轻松搜索编程问题的解决方案

目录 简介首次用户技术特点竞品和相关项目进一步阅读 简介 howdoi 一个在终端中查找编程问题的命令行工具和 python 库&#xff0c;可用于从 Stack Overflow 等编程社区获取搜索问题的答案&#xff0c;并将它们以代码片段的形式显示在命令行中。 首次用户 本文提供了一个dem…

实测运行容器化Tomcat服务器

文章目录 前言一、拉取Tomcat 9.0镜像二、运行容器化Tomcat服务器三、访问Tomcat官网首页测试 总结 前言 运行容器化Tomcat服务器&#xff0c;首先确保正确安装docker&#xff0c;并且已启动运行&#xff0c;具体安装docker方法见笔者前面的博文《OpenEuler 下 Docker 安装、配…

Enhanced Table如何安装?

githup项目地址&#xff1a; https://github.com/fbaligand/kibana-enhanced-table/releases/tag/v1.12.0

R门 - rust第一课陈天 -内存知识学习笔记

内存 #mermaid-svg-1NFTUW33mcI2cBGB {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-1NFTUW33mcI2cBGB .error-icon{fill:#552222;}#mermaid-svg-1NFTUW33mcI2cBGB .error-text{fill:#552222;stroke:#552222;}#merm…

品融电商:新形势下电商平台如何助力品牌长期经营

品融电商&#xff1a;新形势下电商平台如何助力品牌长期经营 在过去几年中&#xff0c;随着内容电商的兴起&#xff0c;一批新兴品牌通过精准的内容种草和互动营销迅速打开市场&#xff0c;实现了从“0到1”的品牌起步阶段。比如&#xff0c;新品牌SIINSIIN通过小红书等内容电商…

C语言中操作符详解(下)

C语言中操作符详解_下 放在最前面的1、条件操作符&#xff08;三目操作符&#xff09;1.1、定义1.2、举例分析&#xff1a;&#xff08;上代码&#xff09;输出结果&#xff1a;代码的解释&#xff1a; 2、逗号表达式2.1、定义2.2、举例分析&#xff1a;&#xff08;上代码&…

渐进式JavaScript框架Vue 3 入门

目录 前言1. Vue 3 的基础入门1.1 什么是 Vue.js1.2 局部使用 Vue 2. Vue 3 的基本配置2.1 准备 HTML 页面并引入 Vue 模块2.2 创建 Vue 应用实例 3. Vue 的数据绑定与界面渲染3.1 插值表达式 4. 常用指令详解4.1 v-for 指令&#xff1a;列表渲染4.2 v-bind 指令&#xff1a;绑…