背景描述
有時候Python應用的代碼在本地開發環境運行十分正常,但是放到線上以后卻出現了莫名其妙的異常,經過再三排查以后還是找不到問題原因,于是就在想,要是可以在服務器環境中進行單步跟蹤調試就好了。
然而,在服務器系統上安裝一個IDE肯定是不現實的;通過SSH遠程到服務器端,采用pdb進行調試雖然可行,但是操作還是較為繁瑣,而且也不夠直觀。
那么,是否可以將開發環境中的IDE與服務器環境相連,實現利用開發環境的IDE調試服務器環境中運行的程序呢? 答案是肯定的,這就是遠程調試(Remote Debug)。
遠程調試的工作原理
遠程調試的功能在Eclipse、IntelliJ IDEA等大型IDE中均有支持,實現原理都基本相同,這里采用PyCharm進行說明。
在遠程調試的模式下,PyCharm(IDE)扮演服務端(Server)的角色,而運行在遠程計算機上的應用程序扮演客戶端(Client)的角色。正因如此,進行遠程調試時,需要先在本地開發環境中設定端口并啟動IDE,IDE會對設定的端口開始監聽,等待客戶端的連接請求;那遠程計算機中的應用程序又是怎樣與IDE建立通訊連接的呢?
針對遠程調試功能,PyCharm提供了pydevd模塊,該模塊以pycharm-debug.egg的形式存在于PyCharm的安裝路徑中。遠程計算機安裝該庫文件后,然后就可以調用pydevd.settrace方法,該方法會指定IDE所在機器的IP地址和監聽的端口號,用于與IDE建立連接;建立連接后,便可在IDE中對遠程在遠程計算機中的程序進行單步調試。
使用PyCharm進行遠程開發和調試
你是否經常要在Windows 7或MAC OS X上面開發Python或Web應用程序,但是它們最后需要在linux上面來運行呢? 我們經常會碰到開發時沒有問題但是到了正式的Linux環境下面卻出現問題。那么怎樣保證開發環境跟運行環境的一致呢?
通常有兩種方法解決。一種是使用PyCharm內置支持的Vagrant
,這個教程可以參考Vagrant開發環境配置。 不過很遺憾的是我自己在試驗過程中啟動VirtualBox虛擬機時候老是報錯,暫時還沒解決,讀者可以自己試著測試看行不行。 第二種方式就是通過PyCharm的遠程解釋器加上文件同步功能,實現本地編輯代碼->同步到服務器->通過遠程debug來調試測試程序。目前我選擇的是第二種,雖然比第一種更笨拙點。
遠程調試的功能在Eclipse、IntelliJ IDEA等大型IDE中均有支持,實現原理都基本相同,這里采用PyCharm進行說明。
遠程服務器的同步配置
遠程服務器IP地址192.168.203.95,開啟ssh服務,安裝python版本2.7。我用一個在PyCharm里面的core-python項目來做演示。
首先我們需要配置PyCharm通服務器的代碼同步,打開Tools | Deployment | Configuration
點擊左邊的“+”添加一個部署配置,輸入名字,類型選SFTP
確定之后,再配置遠程服務器的ip、端口、用戶名和密碼。root path是文件上傳的根目錄,注意這個目錄必須用戶名有權限創建文件。
然后配置映射,local path是你的工程目錄,就是需要將本地這個目錄同步到服務器上面,我填的是項目根目錄。 Deploy path on server 這里填寫相對于root path的目錄,下面那個web path不用管先
如果你還有一些文件或文件夾不想同步,那么在配置對話框的第三個tab頁“Excluded path”里面添加即可,可同時指定本地和遠程。
還有一個設置,打開Tools | Deployment | Options,將”Create Empty directories”打上勾,要是指定的文件夾不存在,會自動創建。
|
新聞熱點
疑難解答