时间:2021-07-01 10:21:17 帮助过:55人阅读
只是想找一下思路,听听大神的意见,不求他人帮忙做出详细方案,只求指出攻关方向。本人会PHP/Java,能对照百度写一点Python。
在本地局域网中,有台服务器跑php网站,这台服务器处于深深的内网中(动态公网IP+网管不给做端口转发);另有一台服务器,处于xx云的机房中,有独立公网IP,跑php用于与微信对接。现在想做一个功能,能让微信发送的信息途径xx云主机转发至局域网中服务器上。xx云主机是Linux系操作系统,可考虑PHP/Python/Java的运行;局域网主机是台普通PC,windows操作系统,可运行PHP/Python/Java,两台主机均配备了MySQL数据库(也是本问题选用的数据库).不知诸君有没有什么比较精妙的思路。。
现在我初步有几种思路,还求各位评点,谢谢!
1.微信->云主机(PHP)->数据库
局域网使用Python或者Java轮询获取新增数据到本地数据库。
2.微信->云主机(PHP)->跨进程传送至Python写的Socket服务器
局域网使用Python或者Java与云主机建立Socket链接,实时通信存入数据库。
3.微信->云主机(PHP)->数据库.
本地数据库与远程数据库创建主从数据库同步(关键是远程可以只写不查)
4.微信->云主机(PHP)->数据库
本地编写程序直接连接两个数据库做一些操作。。
以上便是我针对这个问题思考的一些结果,感觉每个方法都会影响整体系统的速度与效率。
可以使用redis的订阅/发布功能,消息能够即时传递
我来给你第二种思路增增粗
微信->云主机(PHP)->起一个rabbitMQ的消息队列server, 把微信消息扔进队列->局域网主机起一个rabbitMQ的client, 从server端取出消息->扔进数据库
整个消息传输过程异步进行, 哪一个环节都不会有阻塞, 妥妥的, 不用再造轮子了
方案很多,就像你自己给出的1、2、3、4一样,这个时候就要看业务场景:
时间紧吗?
数据量大吗?
时延要求高吗?
并发量如何?
软硬件投入有限制吗?
不能用花生壳吗
这4个方案在理论上都是可行的。但实际场景中记得要注意这几点:
1、你的所有方案都是写操作,如果有读操作的话,部分方案就很难办了,靠异步轮询的话肯定会有数据不一致
2、保持长连接进行通信的话,如果短时间内没有数据,防火墙会不会把你的链接咔嚓掉。这是一个非常棘手且非常常见的大问题,尤其是网管不给做端口转发这种糟糕的前提下。
3、对于方案4,你的网络延迟会不会对用户操作造成僵死或者脏数据。
天朝网络质量很差的,尽量避免多个远程服务器处理一个线性操作,也尽量避免远程长连接。
一般局域网内做微信服务器,都是通过端口转发(如果是动态ip的话还要配动态域名)。现在你的php服务器本质上不处理业务,只做代理,那我有两个方案,1是在公网服务器上搭建nginx,通过动态域名技术反向代理到你的局域网服务器上 2,使用服务中间价,比如java的dubbo,在外网服务器远程调用局域网内的服务