只是想找一下思路,聽聽大神的意見,不求他人幫忙做出詳細方案,只求指出攻關方向。本人會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)->資料庫
本地編寫程式直接連接兩個資料庫做一些操作。 。
以上便是我針對這個問題思考的一些結果,感覺每個方法都會影響整體系統的速度與效率。
回覆內容:
只是想找一下思路,聽聽大神的意見,不求他人幫忙做出詳細方案,只求指出攻關方向。本人會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,在外網伺服器遠端呼叫區域網路內的服務

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP在數據庫操作和服務器端邏輯處理中使用MySQLi和PDO擴展進行數據庫交互,並通過會話管理等功能處理服務器端邏輯。 1)使用MySQLi或PDO連接數據庫,執行SQL查詢。 2)通過會話管理等功能處理HTTP請求和用戶狀態。 3)使用事務確保數據庫操作的原子性。 4)防止SQL注入,使用異常處理和關閉連接來調試。 5)通過索引和緩存優化性能,編寫可讀性高的代碼並進行錯誤處理。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP可以輕鬆創建互動網頁內容。 1)通過嵌入HTML動態生成內容,根據用戶輸入或數據庫數據實時展示。 2)處理表單提交並生成動態輸出,確保使用htmlspecialchars防XSS。 3)結合MySQL創建用戶註冊系統,使用password_hash和預處理語句增強安全性。掌握這些技巧將提升Web開發效率。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Dreamweaver Mac版
視覺化網頁開發工具

Dreamweaver CS6
視覺化網頁開發工具