跳到主要內容

PostgreSQL on Cygwin

最近嚐試在Windows 7上,透過Cygwin環境來安裝PostgreSQL DB,可是一直遭遇到困難。

上網查了一些資料,有一篇文章說明在「/usr/share/doc/Cygwin/postgresql.README」裡,有相關的設定方式。依README執行了下列的指令:

$ cygrunsrv -S cygserver

卻一直回報「cygrunsrv: Error starting a service: OpenService:  Win32 error 1060」的訊息,網路上也一直沒有找到相關且明確的解決辦法。依照過往的經驗,並查詢了指令的用法/意圖,我判斷應該是服務註冊及權限出現了問題。因此以系統管理員身份執行Cygwin,並執行以下指令:

$ export PATH=/usr/sbin:$PATH 
$ cygrunsrv -I cygserver --path /usr/sbin/cygserver.exe 
$ cygrunsrv -S cygserver

完成後,執行README中所述的後續指令:

$ initdb -D /path/to/postgresql/data
$ createdb
$ pg_ctl start -D /path/to/postgresql/data -l /var/log/postgresql.log
$ psql

至此完成PostgreSQL於Cygwin環境的安裝設定。

補充說明:這個方法只適合單機操作的開發環境。若要以Service的方式運行,則需另參考README中的說明。

留言

這個網誌中的熱門文章

Linux 雙螢幕顯示設定

回頭看了一下 Blog 的更新日期,上一篇發文已經是三年以前。 最近手上剛好有一部新筆電安裝了 Linux 後,想透過 HDMI 界面來連接第二顆螢幕,可是卻怎麼樣也沒有辦法投放到第二顆螢幕上。寫下這篇文章作為紀錄。 我的配備如下: Intel 整合顯示晶片 Nvidia Geforce GTX-1050 顯示晶片 筆電內建 LCD 螢幕 外接 BenQ EL2200 螢幕 HDMI -> VGA 轉換器  透過 xrandr -q 指令來查詢目前的顯示狀況:  畫面中出現我的 HDMI 界面是處於 "disconnected" 的狀態,可是我明明就是把轉換器插在 HDMI 座上呀! 又透過了 nvidia-xconfig --query-gpu-info 查詢,我可以查到我的 Nvidia GPU 已經被驅動,同時連現在螢幕上。 到這裡為止,我查到的資料及問題解法,不外乎是要求安裝 GPU 驅動程式(我已經安裝了,所以可以透過 nvidia-xconfig 查到 GPU 的狀態),或是使用 xrandr 增加顯示模式,然後把訊號投放至螢幕上;但這些都沒有辦法真正解決我的問題,螢幕的指示燈處於無訊號的狀態,螢幕上空蕩蕩的漆黑一片。 因此,我改變思考的方向,將問題的調整為 XWindow 的設定問題,並著手尋找將系統設定為雙螢幕的可能。目前新版的 XWindow 已經可以透過自動偵測的方式完成設定,不需要預先準備 xorg.conf 這個設定檔。但是若要自行對 XWindow 進行配置,那勢必需要產生這個檔案。所幸目前的工具很方便,可以透過一些簡單的參數,產生一個基礎檔案;我們再利用這個檔案為基礎,調整為我們需要的配置。 我使用了以下的指令,完成設定檔的產出: Xorg -configure 這個指令只能在 Console 模式下執行,而且執行時需要把目前執行中的 XWindow 停止;完成後,會在執行者的目錄下,產生一個 xorg.conf.new 的檔案。把這個檔案移動到 /etc/X11/ 目錄下,並改名為 xorg.conf 。 nvidia-xconfig 它會參考剛剛的 xorg.conf ,並把 Nvidia 驅動程式相關的設定填入。需要有 root 權限。 ...