溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題

發(fā)布時(shí)間:2021-12-06 14:26:43 來源:億速云 閱讀:287 作者:柒染 欄目:云計(jì)算

這篇文章給大家介紹怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

/etc/init.d/openstack-nova-novncproxy status

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題

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

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題


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)程掛掉。

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題


前臺(tái)顯示啟動(dòng):

/usr/bin/nova-novncproxy --web /usr/share/novnc/

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題


發(fā)現(xiàn)只要raise一拋,novnc則登錄不上去。

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題



因?yàn)檎业搅藢?dǎo)致novnc自動(dòng)死掉的地方,具體為什么報(bào)Invalid Token異常,請(qǐng)自行跟蹤代碼:

怎么解決openstack novnc一段時(shí)間后自動(dòng)掛斷登錄不上問題



當(dāng)然最簡(jiǎn)單的辦法就是直接把異常語句屏蔽掉。(當(dāng)然不贊同,畢竟最好還是找到為什么拋異常的原因)


怎么解決openstack novnc一段時(shí)間后自動(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ò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(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)容。

AI