火山软件开发平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 火山 源码 类库
查看: 9416|回复: 88
打印 上一主题 下一主题

[视窗] 【解决方案】火山视窗服务器插件化开发研究_部件DLL案例

  [复制链接]

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
跳转到指定楼层
楼主
发表于 2023-2-13 14:51:19 | 显示全部楼层 |只看大图 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 创世魂 于 2023-2-13 21:21 编辑


火山视窗服务器插件化开发研究。


现在火山并没有出服务器插件,比如火山java,火山php,火山nodejs 等服务器开发。
比如:php虽然已经快丢进垃圾桶了,但是有个很好的优点,服务器更新基本上直接丢进去php文件覆盖就可以了。可以非常方便实现动态更新。
(夸张一下请勿较真,毕竟php依然坚挺)震惊php排名第十


火山没有这些服务器开发,只能依靠windows开发服务器,这就面临一个问题,如何动态更新。


毕竟exe程序想要更新必须关闭软件才能实现,关闭软件也就意味着服务器关闭。

不过还好有另外一条路,那就是通过dll热加载实现,业务逻辑放进dll。需要修改的时候就修改dll文件即可。

但是这又面临一个问题,如果只想某个业务模块停止,如何做?


其实也很简单,这就需要在软件服务器开发初期,对服务器所需要的功能模块拆分。
比如:注册dll、登陆dll、等等……如果注册dll需要维护就单独停止注册dll业务。


于是乎就有了下面的案例。
本案例客户端和服务器是基于HP_pack通讯协议实现,实现了服务器注册登陆业务分离,当某个模块需要维护的时候停止此模块即可。
因为案例写的比较简单,仅供演示参考,请勿用于生产环境。








下载例子后,注意将“登陆DLL”和“注册DLL”两个项目右键,进行编译发布版,然后运行主服务器才能使用。







服务器插件化开发后:
      优点:可以对模块进行动态更新,方便服务器维护升级。
      缺点:
            1、开发周期较长,对服务器程序逻辑思维有较高的要求。
            2、需要提前规划好各个模块业务。
            3、最大的缺点是,如果需要新增插件,需要停止整个服务器。因为插件逻辑是在“主服务器”源码中实现,新增插件必须对主服务器进行修改重新编译。
         
最后:至于能不能实现真正的热更新,新增插件也热更新?因为服务器插件是基于部件DLL实现,并不是自己通过类库动态载入的,所以就目前这个源码来说不能实现。

至于通过部件DLL能不能实现动态插件,比如放一个dll到目录中刷新插件列表,就可以直接加载新插件功能。。
目前好像部件不太好实现,如果有大佬有部件DLL的相关解决方案,欢迎贡献案例。




游客,如果您要查看本帖隐藏内容请回复











评分

参与人数 1金钱 +1 收起 理由
东子 + 1 哈哈,什么叫PHP“快丢进垃圾桶”,那请问.

查看全部评分

安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
沙发
 楼主| 发表于 2023-2-13 21:20:47 | 显示全部楼层
1503123 发表于 2023-2-13 15:37
谁说的PHP丢垃圾桶了,

哈哈哈,只是夸张一下。因为网上很多培训班啥的,基本都是教java啥的。。动不动就是java各种技术栈。

实际上php市场还是非常大。
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
板凳
 楼主| 发表于 2023-2-13 21:23:13 | 显示全部楼层
东子 发表于 2023-2-13 19:39
哈哈,什么叫PHP“快丢进垃圾桶”,那请问火山和易语言了?

夸张一下,毕竟php底蕴生态和排名还是嘎嘎深的
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
地板
 楼主| 发表于 2023-2-13 21:23:57 | 显示全部楼层
龙纹 发表于 2023-2-13 16:03
据我所知第3个缺点可以通过 boost.dll 这类的技术手段避免

要火山里面能用的方案……不知道有没有大佬贡献一下解决方案,我暂时反正没想到。
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
5#
 楼主| 发表于 2023-2-14 13:29:20 | 显示全部楼层
glbosom 发表于 2023-2-14 11:56
我的三层架构也是这个思想

但是不知道如何才能动态的新增插件。。
不知道大佬有什么方案。。
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
6#
 楼主| 发表于 2023-2-19 09:12:07 | 显示全部楼层
qaz2428119 发表于 2023-2-15 09:57
其实也不算很难,只需留出一定的协议口,把插件与服务器之间的通信搞好,就可以实现真正的热插拔
麻烦的就是如 ...

重点是最好是用部件dll实现,目前来说部件dll好像无法实现热插拔。
这就比较难搞了。。
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
7#
 楼主| 发表于 2023-2-19 09:13:52 | 显示全部楼层
glbosom 发表于 2023-2-14 13:40
我用的不是部件,我用的是动态链接库 通过API动态加载和卸载来更新插件

...

这种肯定可以的,但是部件dll暂时就不知道了。有空再看看。。。
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
8#
 楼主| 发表于 2023-2-19 09:14:56 | 显示全部楼层
CPUCN 发表于 2023-2-14 15:27
我倒是觉得,推出一个部件开发的标杆例子倒是很好的
至于热更新没有太大的必要
毕竟这样的需求太少.

确实
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

439

主题

1万

帖子

3万

积分

超级版主

Rank: 8Rank: 8

积分
36466
9#
 楼主| 发表于 2023-2-19 09:16:05 | 显示全部楼层
CPUCN 发表于 2023-2-14 15:27
我倒是觉得,推出一个部件开发的标杆例子倒是很好的
至于热更新没有太大的必要
毕竟这样的需求太少.

热更新还是需要的。看用户量了,如果用户少,找个用户在线少的时候提前发公告更新服务器就行。。

用户多了就需要热插拔了。。
安卓无障碍实战课:点击查看
交流群:641526939
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|火山软件开发平台 ( 鄂ICP备18029190号 )

GMT+8, 2024-5-6 14:40 , Processed in 0.093447 second(s), 22 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表