ubuntu16.04-x64系统中Jexus web server部署.NetCore和端口分析引发的猜想!

本文详细介绍如何在Ubuntu系统上使用Jexus Web Server部署.NET Core应用程序,并通过实例演示如何配置监听端口,确保应用程序能够被正确访问。

您有这样的牢骚么?

有一周没更新博客了,简单说下在干什么吧;主要是公司安排对接某旅游大公司的接口,接口数量倒也就10个左右,对接完后还需要加入到业务系统中和App端,因此还是需要花点时间的;时间上来说业务需求安排在6月最后一周上线,整个3周的时间,就本人一人负责,由于在这之前对接过另外一个公司接口,我已经搭建好了整体架构和提供给app端接口了,因此主要还是对接某公司接口而已,至于细节上的东西改改后台系统,调调数据格式应该就差不多了;就本人开发的熟练度来讲一周时间基本能搞定,其他剩余时间就测试,喝喝茶,学习一下;谁知。。。由于接口方说明文档不全,接口几乎是每位技术负责一两个接口(没错这就是大公司,分得就这么细),而且有疑问通过qq咨询时响应慢(可能别人大公司的人就是忙),就这样来到第一周的星期五,从app测试结果和对接接口几乎都完成的情况来看还是不错的(我的方式对接一个接口就嵌入到业务中,所以可以直接拿app测试),谁知第二周的时候,也就是本周星期二我在测试多人下单出现了异常,随后联系对方,结果被告知对接的这个下单接口不是最新的,但是除此之外其他几个接口都是最新的,最新的下单接口我们等一段时间才上线,等上线了在对接吧;来到此时我只能无语(谁叫您们是大公司呢),纯属浪费我对接和咨询的“热情”;

部署前的准备

来到这里就开始进入正题了,首先要准备ubuntu系统(后面我会单独写一篇怎么在OracleVM中安装ubuntu和注意事项),这里我是16.04-x64版本,为什么我重点写明版本号呢,因为我在官网直接下载最新的Jexus包后,尽然运行不起来,后来在善友兄文章中找到了个地址,安装试运行后是可以的也同样标记的是最新版,只不过后面带了个64位的标记,这是一个悲催的天;

我们还需要一个.netcore程序,为了测试方便我这里创建的是一个api程序,并且api的action里面这样修改了下:

1 [HttpGet]
2         public IEnumerable<string> Get()
3         {
4             return new string[] {$"这个站点是:{Request.Host.Host}:{Request.Host.Port}" };
5         }

输出当前应用程序对应的ip和端口,因为在后面为了更好的测试以及区分;这里也简单改造了下Program.cs中的代码,同样也是为了方便测试:

 1  public static void Main(string[] args)
 2         {
 3             var builder = new WebHostBuilder()
 4                 .UseKestrel();
 5             //参数指定端口
 6             builder = args.Length > 0 ? builder.UseUrls(args[0]) : builder;
 7             var host = builder.UseContentRoot(Directory.GetCurrentDirectory())
 8                   .UseIISIntegration()
 9                   .UseStartup<Startup>()
10                   .UseApplicationInsights()
11                   .Build();
12             host.Run();
13         }

改完代码后,需要生成运行包,怎么生成这里就不讲了,有兴趣的朋友可以去看这里Asp.NetCore1.1版本没了project.json,这样来生成跨平台包;然后通过多种方式把程序包传到虚拟机上,这里我通过共享目录的方式传递的,如果有朋友需要以后有机会分享吧;

再来剩下的就是在ubuntu中使用Jexus web server服务了,为了我虚拟机空间着想,这里我是在tmp中操作的,主要以下步骤,打开终端:

1. cd /tmp(进入临时目录)

2. wget linuxdot.net/down/jexus-5.8.2-x64.tar.gz(下载jexus文件包)

3. tar zxvf jexus-5.8.2-x64.tar.gz(解压到当前目录,无需安装)

4. chmod o+w /tmp/jexus/siteconf(为了方便设置jexus文件夹中的siteconf配置文件夹可以直接操作)

5. chmod o+w /tmp/jexus/siteconf/default(设置默认配置default文件可直接通过打开文件方式修改 注:本人不喜欢通过命令来修改,才有此步骤)

6. cd jexus(进入jexus目录  注:由于如果按照我步骤操作的话这样可以直接进入jexus目录,实际jexus目录在 cd /tmp/jexus)

7. ./jws start(测试jexus是否能正常运行,就我写本篇博客的时候第一次执行这命令返回的结果是:Failure,原因是我没用root权限执行命令,改成root执行命令就行了,怎么root以后有机会再讲)

 

Jexus web server开始部署.NetCore

首先直接通过点击文件夹的方式进入如下目录(您也可以通过终端进入,个人喜好便捷):/tmp/jexus/siteconf;能够看到名称问default的文件,此文件在安装时是非root权限只读的,由于我们在上面使用命令:chmod o+w /tmp/jexus/siteconf/default设置了运行其他权限的用户都能修改内容,所以这里我直接改,其他信息暂时不改动,只需要增加apphost节点:

1 port=80
2 root=/ /var/www/default
3 hosts=*    #OR your.com,*.your.com
4 #增加apphost节点
5 AppHost={CmdLine=dotnet /home/wangrudong003/netcore/publish01/T_Jexus.dll;AppRoot=/home/wangrudong003/netcore/publish01;Port=5000}

增加apphost节点的几个属性说明:

CmdLine:执行命令(熟悉一点.netcore运行的朋友可能知道,.netcore运行命令可以这样:dotnet xxx.dll这样就能跑起来程序了,同理可以看成一样的,但是需要指定应用程序具体目录,这里我的是 /home/wangrudong003/netcore/publish01 )
AppRoot:表示应用程序的目录,这里我的是 /home/wangrudong003/netcore/publish01
Port:监听端口;

 

jexus注意点(大家可以去这里详细了解:https://www.linuxdot.net/bbsfile-3084):
port=80:表示通过jexus来监听80端口,以此来访问我们的  /home/wangrudong003/netcore/publish01/T_Jexus.dll  程序
root=/ /var/www/default:指定的虚拟目录

最后root权限进入cd /tmp/jesux目录,然后开启服务:./jws start  ;如果不出意外的话,您也能够看到如下截图信息:

然后咋们来通过80端口访问以下我们部署的接口(这里我ubuntu服务器的ip是172.16.9.66):http://172.16.9.66/api/values,访问成功的截图:

 

分析一下AppHost配置中的Port是否起作用

有上图测试我们看到了通过80端口能正常访问我们的接口站点,现在我们通过linux命令,查看下服务器上所监听的端口,查看tcp监听端口命令: sudo netstat -lntp ,能投得到如图:

由图能够看出来jexus服务监听的80端口,dotnet命令执行的5000端口;为了更好的测试apphost的port的作用,我们需要把default文件中的port为5000端口改成5001来测试,改完之后的配置:

1 AppHost={CmdLine=dotnet /home/wangrudong003/netcore/publish01/T_Jexus.dll;AppRoot=/home/wangrudong003/netcore/publish01;Port=5001}

然后需要重启jexus服务,通过如下命令: ./jws restart :

重启完之后,我们又来访问:http://172.16.9.66/api/values,这个时候就访问不了接口了:

尽管我们的jexus服务器是ok状态,但是接口已经无法访问了,那么我们再来看看监听的端口:

端口图对比分析

这张和之前端口截图对比,能够发现dotnet执行的还是5000端口,和我们修改配置文件的port:5001不能对应,这有点奇怪,就这点能够让我们大胆猜想jexus的这个port端口设置没有效果;而最后5000端口应该还是dotnet自带的默认端口;

疑问

然而又让我们奇怪的是,如果5000端口运行没问题,那么为什么jexus公布出去的80端口无法访问api接口能,我们又来大胆猜想,是不是由于我们设置的jexus的port:5001端口也真实监听的5000不对应造成的呢?为了测试我们再一次修改下AppHost的配置信息:

AppHost={CmdLine=dotnet /home/wangrudong003/netcore/publish01/T_Jexus.dll http://127.0.0.1:5001;AppRoot=/home/wangrudong003/netcore/publish01;Port=5001}

这次我们按照netcore的命令格式:dotnet xxx.dll http://127.0.0.1:5001来设置下netcore监听的端口,这也就是为什么开篇部分我修改Program.cs中代码的原因,一切为了测试猜想;同样修改完后,我们执行jexus服务的命令:./jws restart ;命令执行ok有,先来访问下80端口的接口:

此时能够正常访问咋们的接口了,那最好需要验证的就是看看监听端口了:

第二幅与第三幅端口图大比拼分析

通过上面第三方图能够看到netcore程序此时绑定的是5001端口,这个时候由jexus开放出去的80端口也能正常访问咋们的接口了,那说明我们在jexus的defaut文件中的apphost节点中的port:5001必须要与dotnetcore自身监听的端口一致,没错一致;假如jexus的端口是8080,那么netcore监听的端口也必须是8080,这样咋们通过jexus开放出来的地址才能正常的访问;好了到这里本篇分享文章就结束了,希望能给您带来好的帮助,也希望大家多多点赞推荐,谢谢!!!

<think>我们正在Ubuntu 16.04系统上安装Qt 5.7.7,并且有27个分卷压缩文件(从ubuntu16.04-Qt5.7.7z.001到ubuntu16.04-Qt5.7.7z.027)。我们需要将这些分卷文件合并并解压安装。 步骤: 1. 确保所有分卷文件都在同一个目录下,并且文件名连续正确。 2. 安装必要的工具(如果尚未安装)来处理7z分卷压缩文件。 3. 使用7z工具合并并解压分卷文件。 4. 安装Qt 5.7.7。 详细步骤: 步骤1:确认分卷文件完整 将所有的分卷文件(共27个)放在同一个目录下,例如~/Downloads/qt5.7.7。 步骤2:安装p7zip-full 在Ubuntu中,我们可以通过apt安装7z工具: ```bash sudo apt update sudo apt install p7zip-full ``` 步骤3:合并并解压分卷文件 进入分卷文件所在的目录,然后使用7z命令解压。由于分卷文件是以.7z.001、.7z.002等结尾的,我们可以使用以下命令: ```bash 7z x ubuntu16.04-Qt5.7.7z.001 ``` 注意:只需要指定第一个分卷文件,7z会自动识别并合并后续分卷。 步骤4:等待解压完成 解压后,你会得到一个完整的Qt安装目录。 步骤5:运行安装程序 进入解压后的目录,通常里面会有一个安装脚本(可能是.run文件)或者直接是Qt的安装文件。假设解压后得到一个.run文件,我们可以运行: ```bash chmod +x qt-installer.run # 如果文件没有执行权限,需要添加 ./qt-installer.run ``` 然后按照图形安装程序的指引进行安装。 注意:如果安装包不是可执行文件,而是已经编译好的Qt库,那么可能不需要运行安装程序,只需要将解压后的目录放在合适的位置,然后在Qt Creator中设置该路径即可。 步骤6:配置环境(可选) 如果需要,可以将Qt的bin目录添加到PATH环境变量中。例如,如果安装到/opt/Qt5.7.7/,则可以将以下内容添加到~/.bashrc中: ```bash export PATH=/opt/Qt5.7.7/Tools/QtCreator/bin:$PATH ``` 注意:以上步骤假设分卷压缩文件是完整的,并且没有损坏。如果解压过程中出现错误,需要重新下载损坏的分卷。 引用说明: 在安装过程中,我们使用了apt命令来安装依赖工具,这参考了Ubuntu包管理的一般做法[^3]。而分卷压缩文件的解压方法则是7z工具的常规用法。 相关问题: 1. 如何验证分卷压缩文件的完整性? 2.Ubuntu中如何设置Qt Creator的环境变量? 3. Qt 5.7.7在Ubuntu 16.04上的兼容性如何?</think>### Ubuntu 16.04安装Qt 5.7.7分卷压缩文件指南 #### 步骤1:合并分卷文件 1. **确认所有分卷完整** 确保27个分卷文件(`ubuntu16.04-Qt5.7.7z.001` 到 `ubuntu16.04-Qt5.7.7z.027`)在同一目录下,无缺失或重命名错误。 2. **安装7z解压工具** ```bash sudo apt update sudo apt install p7zip-full # 提供7z命令支持[^3] ``` 3. **合并并解压文件** 在分卷文件目录执行: ```bash 7z x ubuntu16.04-Qt5.7.7z.001 # 自动识别后续分卷 ``` 解压后得到完整Qt安装包(通常是`.run`文件或目录)。 #### 步骤2:安装Qt 5.7.7 1. **赋予执行权限** ```bash chmod +x qt-opensource-linux-x64-5.7.7.run # 替换为实际文件名 ``` 2. **图形化安装** ```bash ./qt-opensource-linux-x64-5.7.7.run ``` - 选择安装路径(建议默认`/opt/Qt5.7.7`) - 勾选所需组件(至少选择`Desktop gcc`) - 接受许可协议完成安装 3. **终端安装(无图形界面时)** ```bash ./qt-opensource-linux-x64-5.7.7.run --script script.qs # 需提前配置脚本 ``` #### 步骤3:配置环境 ```bash # 添加Qt Creator到PATH echo 'export PATH="$PATH:/opt/Qt5.7.7/Tools/QtCreator/bin"' >> ~/.bashrc source ~/.bashrc ``` #### 验证安装 ```bash qtcreator --version # 应显示Qt Creator 4.3.1 (基于Qt 5.7.7) ``` #### 常见问题解决 - **分卷损坏**: 用`7z t ubuntu16.04-Qt5.7.7z.001`校验完整性,重新下载损坏分卷。 - **依赖缺失**: 安装基础库: ```bash sudo apt install libgl1-mesa-dev libxcb-xinerama0 ``` - **权限问题**: 解压时用`sudo 7z x ...`,但建议用普通用户安装到`~/Qt`目录。 > 提示:Qt 5.7.7在Ubuntu 16.04兼容性良好,但需注意GCC版本应为5.4[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值