質問

openShiftにDIYアプリケーションを構築しようとしています。この例から始めました:

HTTPS://www.openshift.com/blogs/how-to-build-java-websocket-applications-using-the-jsr-356-api

ローカルで実行した場合は、完璧に機能します。DIY OpenShiftカートリッジにコードをアップロードしてコンパイルすると、エラーが発生します。サーバーがポート8000の$ OpenShift_DIY_IPに接続するようにコードを変更しましたが、コードがLine Server.Start()に達すると;次のエラーでクラッシュします。

私は何をしていますか?私は他の港(17500とON)をいかなくても試しました。

エラー:

Binding server to 127.7.177.1:8000
Jun 04, 2014 10:28:02 AM org.glassfish.tyrus.server.ServerContainerFactory create
INFO: Provider class loaded: org.glassfish.tyrus.container.grizzly.GrizzlyEngine
java.net.SocketException: Permission denied
at sun.nio.ch.Net.bind0(Native Method)
at sun.nio.ch.Net.bind(Net.java:444)
at sun.nio.ch.Net.bind(Net.java:436)
at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:214)
at sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74)
at org.glassfish.grizzly.nio.transport.TCPNIOBindingHandler.bindToChannelAndAddress(TCPNIOBindingHandler.java:131)
at org.glassfish.grizzly.nio.transport.TCPNIOBindingHandler.bind(TCPNIOBindingHandler.java:87)
at org.glassfish.grizzly.nio.transport.TCPNIOBindingHandler.bind(TCPNIOBindingHandler.java:64)
at org.glassfish.grizzly.AbstractBindingHandler.bind(AbstractBindingHandler.java:140)
at org.glassfish.grizzly.AbstractBindingHandler.bind(AbstractBindingHandler.java:159)
at org.glassfish.grizzly.nio.transport.TCPNIOTransport.bind(TCPNIOTransport.java:470)
at org.glassfish.grizzly.http.server.NetworkListener.start(NetworkListener.java:658)
at org.glassfish.grizzly.http.server.HttpServer.start(HttpServer.java:264)
at org.glassfish.tyrus.container.grizzly.GrizzlyEngine$1.start(GrizzlyEngine.java:88)
at org.glassfish.tyrus.server.TyrusServerContainer.start(TyrusServerContainer.java:119)
at org.glassfish.tyrus.server.Server.start(Server.java:122)
at org.neo.wordgame.server.WebSocketServer.runServer(WebSocketServer.java:23)
at org.neo.wordgame.server.WebSocketServer.main(WebSocketServer.java:11)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:293)
at java.lang.Thread.run(Thread.java:744)
Please press a key to stop the server.Jun 04, 2014 10:28:04 AM org.glassfish.tyrus.server.Server stop
INFO: Websocket Server stopped.
.

役に立ちましたか?

解決

あなたのアプリケーションはあなたの$ openshift_diy_ipでポート8080を聴く必要がありますが、 http://app-domain.rhcloud.com:8000 または http:// app-domain.rhcloud.com:8443 (SSL)。$ openshift_diy_ipのポート8000へのバインドは機能しません。

他のヒント

それはちょうど DeveloperCorey を言う。OpenShiftに関するWebSocketについての最新ニュース私は見つけることができましたこのブログ記事、あなたが持っていると言っています外部から8000/8443にアクセスする。

ライブ例として、私はWebSocketをOpenShiftに使用してアプリケーションを展開しました。 http://vinbudin-openshift.> http://vinbudin-openshift.>

アプリケーションはまだ動作していますが、長いポーリングに静かに劣化する可能性があるため、 [Chrome Developer Tool Network]タブを調べると、拒否されたWebSocketのアップグレード要求

が表示されます。
Request URL:ws://vinbudin-openshift.anthavio.net/ui/PUSH/?v-uiId=0&v-csrfToken=bcd0c9a6-2a6f-4ddb-8332-7929e4337b2d&X-Atmosphere-tracking-id=0&X-Atmosphere-Framework=2.1.5.vaadin4-jquery&X-Atmosphere-Transport=websocket&X-Atmosphere-TrackMessageSize=true&X-Cache-Date=0&Content-Type=application/json;%20charset=UTF-8&X-atmo-protocol=true
Request Method:GET
Status Code:501 Not Implemented
.

Port 8000でURLを使用する http://vinbudin-openshift.antant ::8000/ ui より良い結果をもたらす

Request URL:ws://vinbudin-openshift.anthavio.net:8000/ui/PUSH/?v-uiId=0&v-csrfToken=bcd0c9a6-2a6f-4ddb-8332-7929e4337b2d&X-Atmosphere-tracking-id=0&X-Atmosphere-Framework=2.1.5.vaadin4-jquery&X-Atmosphere-Transport=websocket&X-Atmosphere-TrackMessageSize=true&X-Cache-Date=0&Content-Type=application/json;%20charset=UTF-8&X-atmo-protocol=true
Request Method:GET
Status Code:101 Switching Protocols
.

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top