背景
我在windows电脑安装了一个VM,使用VM开启了Linux服务器,运行docker,下载服务镜像,然后运行服务,然后遇到了主机无法访问服务的问题。
问题排查
STEP1:首先要开启防火墙端口,这个我的Coolify系列其他文章有详细讲解,可以参考一下哇~~
STEP2:配置虚拟机网络,让主机以及局域网其他网络均可访问你的虚拟机(如何让局域网中的其他主机访问虚拟机)
设置网络
接下来详细介绍 配置虚拟机网络,让主机以及局域网其他网络均可访问你的虚拟机(如何让局域网中的其他主机访问虚拟机)
当前情况
- 同一局域网主机1,主机2都为Windows系统,
- 主机1上安装了VMware,并新增了一台虚拟机,使用CentOS 7系统。
- 虚拟机的网络适配器设置为NAT模式
目标
- 主机1可登录此虚拟机
- 局域网其他主机也可以登录此虚拟机
- 局域网所有机器都可以访问此虚拟机上面部署的服务
开始动工
检查虚拟机设置,确保为NAT模式
检查虚拟机所在的主机1的网络ip
进入虚拟机:虚拟网络编辑器中查看NAT设置中的网关IP
cd /etc/sysconfig/network-scripts/ //进入到网络适配器文件夹中,找到你的网络配置文件
vi ifcfg-eth0 //我的网络配置文件名是ifcfg-eth0,编辑文件
或者通过下面命令来进行搜索
ls | grep 'ifcfg-*'
eth0与ens33的关系:目前的主流网卡为使用以太网络协定所开发出来的以太网卡 (Ethernet),因此我们 Linux 就称呼这种网络接口为 ethN (N 为数字)。 举例来说,主机上面有一张以太网卡,因此主机的网络接口就是 eth0 (第一张为 0 号开始)。新的 CentOS 7 开始对于网卡的编号有另一套规则,网卡的界面代号与网卡的来源有关,网卡名称会是这样分类的:
- eno1 :代表由主板 BIOS 内置的网卡
- ens1 :代表由主板 BIOS 内置的 PCI-E 界面的网卡
- enp2s0 :代表 PCI-E 界面的独立网卡,可能有多个插孔,因此会有 s0, s1... 的编号~
- eth0 :如果上述的名称都不适用,就回到原本的默认网卡编号
所以我们可以通过新建一个网卡文件来设定网络配置,重点是这两行
BOOTPROTO=dhcp
ONBOOT=yes
假如centos7里没有ifcfg-eth0只有 ifcfg-ens33(没有Eth0网卡)
参考命令:
cd /etc/sysconfig/network-scripts/ //进入到网络适配器文件夹中
mv ifcfg-ethXXX ifcfg-eth0 //名字改为ifcfg-eth0
vi ifcfg-eth0 //编辑文件
那就新增一个,参考配置如下:
TYPE=Ethernet
DEFROUTE=yes
PEERDNS=yes
PEERROUTES=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_FAILURE_FATAL=no
NAME=eth0
BOOTPROTO=dhcp
ONBOOT=yes
DNS1=8.8.8.8
保存,然后重启服务
service network restart # 重启网络
ping www.baidu.com # 测试网络
查看IP地址
ip addr
此时我们要做一些测试
- 虚拟机1能ping通www.baidu.com(已达成)
- 虚拟机所在的主机1能ping通虚拟机(已达成)
- 虚拟机能ping通自己所在的主机(已达成)
- 虚拟机所在的主机1能使用linux工具登录虚拟机(已达成)
安装一个nginx,部署一个网页进行测试
cd /var/opt/
wget http://nginx.org/download/nginx-1.22.1.tar.gz
tar -zxvf nginx-1.22.1.tar.gz
yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel
cd nginx-1.22.1
./configure
make install
# 打开配置文件,改为喜欢的端口号
vi /usr/local/nginx/conf/nginx.conf
启动nginx
./usr/local/nginx/sbin/nginx
查看nginx是否启动
ps -ef | grep nginx
使用虚拟机所在的主机1访问虚拟机的网页,测试成功
接下来我们让2,3都可以链接虚拟机
设置VMVare的默认网关(相当于我们设置路由器):
编辑->虚拟网络编辑器->更改设置->选中VM8>点击NAT设置,设置默认网关(根据本地的ipconfig设置)
端口转发
选择“NAT设置”,按照下图进行端口转发的设置。将主机的空闲端口指定为8080(可以指定任意的空闲端口),虚拟机的空闲端口同样指定为8080。然后,在主机2上用主机1的IP+主机1的端口的方式来访问虚拟机1中的网页,如:192.168.0.128:8080。如果这样不能访问成功,请接着做下一步。
配置
回到虚拟机所在的主机1:控制面板\所有控制面板项\网络连接,设置主机ip地址,点击VMnet8,设置ip
最后一点哦,配置虚拟机所在主机的防火墙策略,我直接给它关了,这个不太好,建议小伙伴们去设置一下端口策略哦~~
测试访问
经过一系列配置以后,使用宿主机进行测试访问以下三个地址,我们发现
- VM8地址:http://192.168.33.1:8080/
- 虚拟机ip直连地址:http://192.168.33.128:8080/
- 局域网所有IP通用访问地址:http://192.168.1.6:8080/
经过反复测试,确认是偶然性速度快慢问题,速度应该和局域网网络稳定性有关系
接下来我去搞docker
我们创建一个docker测试项目,进行测试
cd /var/opt/
ls
mkdir docker-test-demo
ls
cd docker-test-demo/
touch Dockerfile
vi Dockerfile
写入以下内容
FROM node:9.2.1-alpine
# Install base packages and set timezone ShangHai
RUN apk update && \
apk add tzdata && \
/bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
WORKDIR /app
COPY ./app /app
RUN npm install
EXPOSE 8090
CMD [ "node", "server.js" ]
补充.dockerignore
touch .dockerignore
.dockerignore写入以下内容
node_modules
npm-debug.log
准备一个简单的nodejs文件
var http = require('http');
http.createServer(function (request, response) {
response.writeHead(200, { 'Content-Type': 'text/plain' });
response.end('Hello World\n');
}).listen(8090);
console.log('Server running at http://127.0.0.1:8090/');
将文件放到我们的dockerfile旁边app目录下
mkdir app
cd app
启动docker以及设置开机启动
systemctl start docker
接下来执行
chkconfig docker on
或者
systemctl enable docker.service
下载构建镜像
下载镜像
docker search node
docker pull docker.io/node:9.2.1-alpine
构建镜像,不要忘了後面還有一個點點哦
docker build -t node:v1 .
启动容器脚本
docker run -d -p 8090:8090 node:v1
成功啦~~
在虚拟机使用
curl http://localhost:8090/
在宿主机使用
http://192.168.33.128:8090/
在其他局域网电脑使用
http://192.168.1.6:8090/
今天就写到这里啦~
- 小伙伴们,( ̄ω ̄( ̄ω ̄〃 ( ̄ω ̄〃)ゝ我们明天再见啦~~
- 大家要天天开心哦
欢迎大家指出文章需要改正之处~
学无止境,合作共赢