您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
/etc/init.d/openstack-nova-novncproxy status
openstack-nova-novncproxy dead but pid file exists
由于沒有日志,無法查看具體原因。直接配置log-file對(duì)應(yīng)這個(gè)進(jìn)程似乎沒有效果,因此采用手動(dòng)起進(jìn)程方式,將日志重定向的ttx.log。
nohup /usr/bin/nova-novncproxy --web /usr/share/novnc/ >> ttx.log &
半天之后,發(fā)現(xiàn)控制臺(tái)仍然登錄不進(jìn)去,查看日志log,發(fā)現(xiàn)出現(xiàn)如下log 異常:
{</usr/lib/python2.6/site-packages/amqp/channel.py:608: DeprecationWarning: auto_delete exchanges has been deprecated 'auto_delete exchanges has been deprecated')) 138: 192.168.10.100: Plain non-SSL (ws://) WebSocket connection 138: 192.168.10.100: Version hybi-13, base64: 'True' 138: 192.168.10.100: Path: '/websockify' 138: handler exception: Invalid Token 138: Traceback (most recent call last): File "/usr/lib/python2.6/site-packages/websockify/websocket.py", line 711, in top_new_client self.new_client() File "/usr/lib/python2.6/site-packages/nova/console/websocketproxy.py", line 56, in new_client raise Exception(_("Invalid Token")) Exception: Invalid Token
|
按照異常直接跟蹤代碼:
vim /usr/lib/python2.6/site-packages/nova/console/websocketproxy.py
if not connect_info: LOG.audit("Invalid Token: %s", token) raise Exception(_("Invalid Token")) |
發(fā)現(xiàn)上述語句出現(xiàn)異常,因此試驗(yàn)強(qiáng)制拋出異常,監(jiān)測(cè)是否該異常會(huì)導(dǎo)致novnc進(jìn)程掛掉。
前臺(tái)顯示啟動(dòng):
/usr/bin/nova-novncproxy --web /usr/share/novnc/
發(fā)現(xiàn)只要raise一拋,novnc則登錄不上去。
因?yàn)檎业搅藢?dǎo)致novnc自動(dòng)死掉的地方,具體為什么報(bào)Invalid Token異常,請(qǐng)自行跟蹤代碼:
當(dāng)然最簡(jiǎn)單的辦法就是直接把異常語句屏蔽掉。(當(dāng)然不贊同,畢竟最好還是找到為什么拋異常的原因)
后續(xù)試驗(yàn)一段時(shí)間,發(fā)現(xiàn)該錯(cuò)誤繼續(xù)重現(xiàn),
經(jīng)過排查試驗(yàn),最后得出結(jié)論:
1、由于/etc/init.d/openstack-nova-novncproxy stop時(shí)候,
每次只將第一個(gè)進(jìn)程kill掉(有時(shí)候是重啟/etc/init.d/openstack-nova-console)
2、而頁面沒點(diǎn)擊一個(gè)控制臺(tái)鏈接就會(huì)對(duì)應(yīng)多個(gè)進(jìn)程
所以每次只是kill掉第一個(gè)進(jìn)程的話,其他進(jìn)程并沒有重啟,這樣導(dǎo)致界面的控制臺(tái)登錄出錯(cuò)
且后面查看 /etc/init.d/openstack-nova-novncproxy staus時(shí)候,是novncproxy dead but pid file exists
最終解決辦法是:將vim /etc/init.d/openstack-nova-novncproxy
將stop的邏輯修改下,將所有的novnc進(jìn)程全部kill掉。(其實(shí)在start時(shí)候只記錄了一個(gè)pid號(hào))
關(guān)于怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。