推送伺服器搭建
㈠ 推送信息的APP需要什麼樣的伺服器
推送的基本原理其實類似,其實就是通過手機和伺服器之間的Socket維持一個TCP長連接,通過這個長連接來實現伺服器和客戶端之間的通信。所以推送服務的提供商都會同時提供一個庫來供第三方引用,這個嵌入的庫會幫助第三方應用維護和伺服器之間的連接,包括許可權校驗,斷開重連等的工作。這樣暴露給第三方開發者的就是一個簡單的介面了,開發人員不必關心網路的斷開與重連,以及心跳檢測等各種復雜的技術問題。當然,除此以外,這些潛入的庫往往還會封裝一些其他的介面,比如幫助你收到消息後顯示在通知欄,展示頁面,甚至激活你的應用,傳遞數據到應用並顯示在應用中的某個界面等。這些功能都可以極大的簡化app開發的工作,有人問我推送和簡訊有什麼區別,我想這些擴展的功能就是和簡訊最大的區別吧。至於,之前那個朋友使用HTTP方式輪詢之所以會出現耗電耗流量的情況也是有原因的,因為HTTP請求最終其實還是通過TCP協議實現的,只不過它的TCP連接是短連接,握手非常頻繁,所以自然就比較耗電,而且HTTP方式是基於文本方式進行通信的,因此協議冗餘比較大,流量消耗自然就大了。而且輪詢方式帶來的問題是,在兩次輪詢之間的時間間隔內是沒辦法拿到伺服器下發的消息的。因此,實時性會大打折扣。而長連接就沒有這些問題,而且還有個好處,就是當你的應用即使不活躍也沒關系,你也可以有辦法觸達,提升活躍度。當然,長連接也會有它的問題,就是開發的難度較大。而且,手機應用的一個特點是移動,大家都是帶著手機跑的。所以,當你跑進電梯或者隧道的話,如果信號不好連接就會斷掉,這個時候程序就得重新連接,這就無形中增加了這個東西的難度。
㈡ 推送是如何實現單伺服器300萬到500萬個長連接的
貌似那個個推模型上跟nginx差不多,建議你仔細研究一下相關文檔、代碼。
單機高連接數好與不好跟業務有一定的相關性。• 服務程序基於事件驅動,可以有效提高吞吐能力;
• 非同步IO;
• 基於內存池的內存管理,申請釋放都要足夠輕;
• 減少進程調度帶來的額外損耗。
㈢ ios 推送是建立在 蘋果推送伺服器嗎
方法/步驟
在developer.apple.com的member center設置AppId屬性,
enable push.
在developer.apple.com的member center創建APN證書,
Development -> Apple Push Notification service SSL (Sandbox) 用於沙盒app
Proction -> Apple Push Notification service SSL 用於AppStore app
創建完畢後,可以第一步AppId的屬性列表中查看到證書名稱
基於第1步修改的AppID重新生成provision file,
在iOS Project中載入此provision file,
這樣編譯出的app才可以獲取到device token(推送唯一標識符)
以下為針對服務端的推送設置步驟--------
在keychain中找到第1步創建的APN證書,
展開此證書,分別導出證書和密鑰,
名稱設為cer.p12和key.p12
打開控制台程序,
使用openssl 將cer.p12及key.p12轉成cer.pem和key.pem
命令如下:
$ openssl pkcs12 -clcerts -nokeys -out cer.pem -in cer.p12
$ openssl pkcs12 -nocerts -out key.pem -in key.p12
測試生成的cer.pem及key.pem是否可用
$ openssl s_client -connect gateway.push.apple.com:2195 -cert cer.pem -key key.pem
註:gateway.push.apple.com:2195用於appStore app;
gateway.sandbox.push.apple.com:2195用於沙盒app;
以上命令執行後會列印一大羅信息,最後處於可輸入狀態,打幾個字元回車後自動斷開連接即為正常。
合並cer.pem及key.pem
$ cat cer.pem key.pem > ck.pem
上傳ck.pem到推送伺服器的推送程序的目錄。
Tip:-----------------------
find / -name "*.php"
查詢推送伺服器php文件目錄用。
scp ~/Desktop/ck.pem [email protected]:/var/www/html
用於上傳本地文件到Linux伺服器用。
9
伺服器php代碼載入ck.pem向蘋果伺服器推送消息:略
客戶端oc代碼獲取token,接收推送消息:略
㈣ 如何自建一個推送伺服器,把信息從伺服器摧送到手機客戶端
找手機客戶客戶端的開發商。
㈤ 如何自己搭建一個xmpp,實現推送消息
Android推送方案分析(MQTT/XMPP/GCM)
蝸牛TT 發布於 4個月前,共有 11 條評論
本文主旨在於,對目前Android平台上最主流的幾種消息推送方案進行分析和對比,比較客觀地反映出這些推送方案的優缺點,幫助大家選擇最合適的實施方案。
方案1、使用GCM服務(Google Cloud Messaging)
簡介:Google推出的雲消息服務,即第二代的G2DM。
優點:Google提供的服務、原生、簡單,無需實現和部署服務端。
缺點:Android版本限制(必須大於2.2版本),該服務在國內不夠穩定、需要用戶綁定Google帳號,受限於Google。
方案2、使用XMPP協議(Openfire + Spark + Smack)
簡介:基於XML協議的通訊協議,前身是Jabber,目前已由IETF國際標准化組織完成了標准化工作。
優點:協議成熟、強大、可擴展性強、目前主要應用於許多聊天系統中,且已有開源的Java版的開發實例androidpn。
缺點:協議較復雜、冗餘(基於XML)、費流量、費電,部署硬體成本高。
方案3、使用MQTT協議(更多信息見:http://mqtt.org/)
簡介:輕量級的、基於代理的「發布/訂閱」模式的消息傳輸協議。
優點:協議簡潔、小巧、可擴展性強、省流量、省電,目前已經應用到企業領域(參考:http://mqtt.org/software),且已有C++版的服務端組件rsmb。
缺點:不夠成熟、實現較復雜、服務端組件rsmb不開源,部署硬體成本較高。
方案4、使用HTTP輪循方式
簡介:定時向HTTP服務端介面(Web Service API)獲取最新消息。
優點:實現簡單、可控性強,部署硬體成本低。
缺點:實時性差。
對各個方案的優缺點的研究和對比,推薦使用MQTT協議的方案進行實現,主要原因是:MQTT最快速,也最省流量(固定頭長度僅為2位元組),且極易擴展,適合二次開發。接下來,我們就來分析使用MQTT方案進行Android消息的原理和方法,並架設自己的推送服務。
如果還不明白的 話,要看分析的話,給你個網址:http://m.oschina.net/blog/82059
自己看看。
㈥ 怎麼實現伺服器給android客戶端主動推送消息
採用MQTT協議實現Android推送功能是一種解決方案。MQTT是一個輕量級的消息發布/訂閱協議,是實現基於手機客戶端的消息推送伺服器的理想解決方案。
常見的解決方案實現原理:
1、輪詢(Pull)方式:客戶端定時向伺服器發送詢問消息,一旦伺服器有變化則立即同步消息。
2、SMS(Push)方式:通過攔截SMS消息並且解析消息內容來了解伺服器的命令,但這種方式一般用戶在經濟上很難承受。
3、持久連接(Push)方式:客戶端和伺服器之間建立長久連接,這樣就可以實現消息的及時行和實時性。
(6)推送伺服器搭建擴展閱讀:
推送消息注意事項:
1、支持第三方推送內容,是要客戶端和伺服器都支持的,客戶端和伺服器都導入推送SDK。
2、伺服器推送內容,可以精確指定推送時間,推送的具體接收人,用戶群,位置。
3、即推送的維度可以使時間,位置,人群。
4、極光使用了兩種不同的通知方式,一種是推送通知,一種是推送消息。
5、如果要使用androidpn,則還需要做大量的工作,需要理解XMPP協議、理解Androidpn的實現機制,需要調試內部存在的BUG。
參考資料來源:網路-伺服器
參考資料來源:網路-Android客戶端
參考資料來源:網路-信息推送
㈦ 如何搭建android推送mptt伺服器
近研究了一下Android推送,在網上搜到了很多種方式,覺得IBM的MQTT協議這種方式還是挺不錯的。
下面介紹一下搭建過程:
需要准備的工具如下:
(1)、下載Mosquitto(MQTT的代理,也可以用IBM的ISMB)
http://mosquitto.org/download/
我下載的是mosquitto-1.1.2-install-win32.exe,根據自己的需要下載,不安裝這個推送不了消息。
(2)、下載AndroidPushNotificationsDemo
https://github.com/toku/Androi ... /archive/master.zip
(3)、下載PhpMQTTClient
https://github.com/toku/PhpMQTTClient/archive/master.zip
將PHPMQTTClient部署到PHP伺服器上,運行,打開mosquitto安裝目錄的mosquitto.exe
㈧ JAVA 伺服器推送數據怎麼做
struts2中有這個機制,還有我一般都用jquery當load頁面或者js事件完成後,做相應的處理,比如:ajax無刷新回調、dwr等。
㈨ 使用第三方推送服務相比自己搭建推送伺服器有哪些優點和缺點
使用第三方推送服務相比自己搭建推送伺服器的優點和缺點,具體如下:1、第三方推送服務優點
(1)具有更加精準的推送能力;
(2)能夠全面的覆蓋所有使用用戶;
2、第三方推送服務缺點
(1)每個品台的側重點不一樣;
(2)PUSH成本不確定;
(3)效果是很難進行評估的。
對於第三方推送服務的選擇,可以先去深圳極光進行了解一下。極光為全球開發者提供穩定高效的即時通訊服務;極光推送搭建起一個高度穩定、可擴展的雲端架構,極大地幫助移動應用開發者節約開發和維護的成本,輕松實現毫秒級的精準推送。
極光還致力於解決 開發、產品、運營在工作中遇到的各類問題,並為大家提供一個思維碰撞、共同提升的互動平台。
㈩ 微信的消息推送服務是自己搭建的還是利用的蘋果的APNS
可以實現,給你一個思路,推送的流程是這樣的,
程序運行起來以後,會判斷是否這個程序要推送,
如果要的話會需要將手機和推送證書生成的
一個唯一標識字元串(decice token)傳
我們自己的伺服器去,伺服器根
據這個token和一個伺服器端的證書文件..