亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > PostgreSQL > 正文

PostgreSQL7.0手冊-程序員手冊 -46. 鏈接動態鏈接的函數

2019-09-08 23:33:42
字體:
來源:轉載
供稿:網友
第四十六章. 鏈接動態鏈接的函數
內容 
Linux 
DEC OSF/1 
SunOS 4.x, Solaris 2.x 和 HP-UX 
在你創建并注冊完用戶定義的函數后,你的工作就基本完成了.但是,Postgres 必須把實現你的函數的目標碼(例如,一個 .o 文件,或一個共享庫)裝載進來.正如我們前面所說,Postgres 在運行時根據需要把你的代碼裝入內存.為了讓你的代碼能夠動態裝載,你可能要把它們用一種特殊的方法編譯和鏈接-編輯它們.本章簡單的介紹在你應該怎樣進行要求的編譯和鏈接,才能夠把你自定義的函數裝載到正在運行的 Postgres 服務器里去. 
如果你有特殊的問題,我們希望你能好好讀一下 C 編譯器 cc(1),和鏈接器,ld(1) 的手冊頁(最好多讀幾便).另外,在回歸測試套件的目錄 PGROOT/src/regress 里包含這個過程的幾個工作樣本.如果你按照這些測試的例子做,你應該沒有任何問題. 

會用到下面幾個術語: 

動態裝載(Dynamic loading)是 Postgres 對一個目標文件的操作.目標文件被拷貝進入運行著的 Postgres 服務器中并且文件里的函數和變量可以被 Postgres 進程內的函數使用.Postgres 利用操作系統提供的動態裝載的機制來實現這個目的. 
裝載和鏈接編輯(Loading and link editing)是你為了生成某種其他類型的目標文件對目標文件做的處理(例如,一個可執行程序或一個共享庫).你使用鏈接編輯程序,ld(1),來執行這些操作.

下面的通用限制和注釋適用于后面的討論: 
給創建函數命令的路徑必須是絕對路徑(也就是說,以 "/" 開頭),該路徑指向一個 Postgres 服務器運行的機器上的該服務器可見的目錄. 
小技巧:相對路徑實際上也可用,但卻是與數據庫存放的路徑(通常是前端應用不可見的)相對的目錄.顯然,把路徑設為與用戶啟動的前端應用相對的路徑是沒有意義的.因為服務器可能是運行在完全不同的機器上!
Postgres 用戶必須能夠訪問賦予創建函數命令的路徑并且能夠讀取該目標文件.這是因為 Postgres 服務器以 Postgres 用戶的身份運行,而不是以運行前端進程的用戶的身份運行.(把文件或一個目錄的權限設成 "postgres" 用戶不能讀和/或不能執行是一個極為常見的錯誤.)
定義在目標文件里的符號名一定不能互相沖突,或與定義在 Postgres 里的其他符號沖突. 
GNU C 通常不提供利用操作系統的動態鏈接器的接口的選項.在這種情況下就必須使用操作系統附帶的 C 編譯器.

Linux
在 Linux ELF 里面,目標文件可以通過聲明編譯選項 -fpic 生成. 
例如, 

# simple Linux example
% cc -fpic -c foo.c
生成一個目標文件 foo.o 就是可以動態裝載入 Postgres.不需要進行附加的裝載或者鏈接編輯工作.

--------------------------------------------------------------------------------

DEC OSF/1
在 DEC OSF/1 里,你可以用帶合適參數的 ld 命令把任何簡單的目標文件變成一個共享的目標文件.此命令用起來象: 
# simple DEC OSF/1 example
% cc -c foo.c
% ld -shared -expect_unresolved '*' -o foo.so foo.o
生成的共享文件馬上就可以裝載入 Postgres.當為創建函數命令聲明目標文件時,我們必需給出共享文件的文件名(以 .so 結尾)而不是簡單的目標文件. 
小技巧:實際上,對于共享目標文件而言 Postgres 并不關心你給這個文件什么名稱.如果你喜歡把你的共享目標文件命名成以 .o 結尾,對 Postgres 而言是沒有問題的,只要你保證你給創建函數命令的文件名也是正確的就行了.換而言之,你必須保持一貫.不過,從務實的角度出發,我們不建議這么做,因為你很容易會把自己搞迷糊,不知道哪個文件是轉換過的共享文件,而哪一個不是.例如,如果目標文件和共享文件都以 .o 結尾,你很難寫一個 Makefile 來做自動連接編輯工作!
如果你聲明的文件不是共享文件,后端就會掛起! 

--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

DEC OSF/1
在 DEC OSF/1 里,你可以用帶合適參數的 ld 命令把任何簡單的目標文件變成一個共享的目標文件.此命令用起來象: 
# simple DEC OSF/1 example
% cc -c foo.c
% ld -shared -expect_unresolved '*' -o foo.so foo.o
生成的共享文件馬上就可以裝載入 Postgres.當為創建函數命令聲明目標文件時,我們必需給出共享文件的文件名(以 .so 結尾)而不是簡單的目標文件. 
小技巧:實際上,對于共享目標文件而言 Postgres 并不關心你給這個文件什么名稱.如果你喜歡把你的共享目標文件命名成以 .o 結尾,對 Postgres 而言是沒有問題的,只要你保證你給創建函數命令的文件名也是正確的就行了.換而言之,你必須保持一貫.不過,從務實的角度出發,我們不建議這么做,因為你很容易會把自己搞迷糊,不知道哪個文件是轉換過的共享文件,而哪一個不是.例如,如果目標文件和共享文件都以 .o 結尾,你很難寫一個 Makefile 來做自動連接編輯工作!
如果你聲明的文件不是共享文件,后端就會掛起! 

--------------------------------------------------------------------------------
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩国产在线播放| 国产精品白嫩初高中害羞小美女| 成人xvideos免费视频| 日本一区二区在线免费播放| 亚洲欧美中文另类| 国产精品久久久久久久午夜| 不卡毛片在线看| 亚洲人成亚洲人成在线观看| 欧美在线性视频| 日本亚洲欧美成人| 久久久久亚洲精品成人网小说| 日韩中文字幕国产| 亚洲自拍偷拍福利| 欧美制服第一页| 久久久久久久久中文字幕| 日韩视频免费中文字幕| 日韩精品免费在线视频观看| 日本欧美国产在线| 亚洲国产精彩中文乱码av在线播放| 狠狠色狠狠色综合日日小说| 亚洲国产精品热久久| 日韩中文字幕亚洲| 中文字幕av日韩| www.欧美三级电影.com| 成人免费淫片视频软件| 另类少妇人与禽zozz0性伦| 久久五月天综合| 日韩在线观看网址| 久久久久久999| 欧美日韩成人在线播放| 日韩在线精品一区| 日韩精品中文在线观看| 欧美日韩精品中文字幕| 久久久久久久香蕉网| 26uuu亚洲伊人春色| 精品久久久久久久久中文字幕| 国产精品h在线观看| 久久精品久久久久久| 欧美在线性爱视频| 色妞一区二区三区| 亚洲成人网av| 91精品国产电影| 欧美激情精品久久久久久久变态| 日韩av综合中文字幕| 欧美大尺度在线观看| 久久久久久18| 久久久久久国产精品三级玉女聊斋| 久久久精品国产一区二区| 国产精品午夜国产小视频| 国产欧美精品日韩| 亚洲人成网在线播放| 国产精品久久99久久| 日韩视频―中文字幕| 国产区精品在线观看| 午夜欧美不卡精品aaaaa| 成人激情视频免费在线| 久久精品国产亚洲一区二区| 亚洲福利视频在线| 欧美另类在线观看| 亚洲女同精品视频| 中文字幕亚洲一区在线观看| 欧美亚洲一级片| 亚洲最大的成人网| 欧美猛交ⅹxxx乱大交视频| 日韩av在线直播| 欧美黄色片在线观看| 91黑丝在线观看| 美女999久久久精品视频| 久久久久久久久久久久久久久久久久av| 综合国产在线观看| 人体精品一二三区| 久久综合久中文字幕青草| 国产综合在线观看视频| 亚洲精品自产拍| 欧美丰满少妇xxxxx做受| 久久久久久18| 国产999精品久久久| 亚洲热线99精品视频| 欧美日韩亚洲高清| 国产精品视频最多的网站| 日韩精品一区二区三区第95| 亚洲香蕉伊综合在人在线视看| 亚洲va码欧洲m码| 国产精品91免费在线| 欧美日韩精品在线视频| 国产精品久久中文| 亚洲区一区二区| 色综合久久精品亚洲国产| 国产一区二区三区日韩欧美| 米奇精品一区二区三区在线观看| 久热精品视频在线| 久久免费福利视频| 青青精品视频播放| 国产美女久久精品| 91精品久久久久久久久久| 668精品在线视频| 久久久久久久久久久久久久久久久久av| 68精品久久久久久欧美| 一区二区三区国产在线观看| 欧美亚洲在线观看| 欧美激情影音先锋| 国产欧美一区二区三区四区| 国产精品免费看久久久香蕉| 日本成人激情视频| 中文字幕亚洲图片| 国产成人福利视频| 欧日韩在线观看| 91久久久久久国产精品| 免费99精品国产自在在线| 成人网在线观看| 欧美激情小视频| 国产精品444| 国语自产精品视频在线看抢先版图片| 欧美黑人极品猛少妇色xxxxx| 国产日韩精品电影| 国产一区二区动漫| 播播国产欧美激情| 亚洲在线视频观看| 国产精品久久二区| 国产亚洲一区二区精品| 色综合久久天天综线观看| 亚洲成人免费网站| www亚洲精品| 日韩亚洲第一页| 国产精品免费久久久久影院| 欧美日韩另类在线| 欧美性受xxxx黑人猛交| 欧美激情图片区| 免费不卡欧美自拍视频| 日韩免费观看在线观看| 中文字幕自拍vr一区二区三区| 国产精品第100页| 国产剧情久久久久久| 国产综合香蕉五月婷在线| 日本高清不卡在线| 亚洲韩国青草视频| 国产精品视频在线播放| 97视频色精品| 欧美性受xxxx白人性爽| 欧美日韩国产区| 日韩大片免费观看视频播放| 国产精品视频免费在线观看| 91久久精品国产91性色| 国产精品高潮呻吟视频| 国内精品小视频在线观看| 国产日韩精品综合网站| 欧日韩不卡在线视频| 国产精品国语对白| 国产91免费观看| 欧美肥老太性生活视频| 91丝袜美腿美女视频网站| 成人日韩av在线| 国产精国产精品| 成人午夜激情网| 午夜精品久久久久久久99黑人| 大桥未久av一区二区三区| 韩日精品中文字幕| 亚洲а∨天堂久久精品喷水| 另类少妇人与禽zozz0性伦| 成人网欧美在线视频| 亚洲xxxx18| 欧美精品激情在线| 国产啪精品视频| 精品国产区一区二区三区在线观看|