ubuntu+mono+PetaPoco+Oracle+.net 程式部署

来源:http://www.cnblogs.com/GYY2046/archive/2017/09/19/7552962.html
-Advertisement-
Play Games

前言:將windows 下開發的 .net 控制台程式(連接Oracle資料庫)部署到 ubuntu 下步驟記錄 2017-09-19 實驗所用機器為虛擬機Ubuntu16.04 amd64 安裝Mono環境 首先添加Mono安裝源: vi /etc/apt/sources.list.d/mono. ...


前言:將windows 下開發的 .net 控制台程式(連接Oracle資料庫)部署到 ubuntu 下步驟記錄  2017-09-19

實驗所用機器為虛擬機Ubuntu16.04  amd64

安裝Mono環境

  首先添加Mono安裝源:

vi /etc/apt/sources.list.d/mono.list

  添加內容:

deb http://download.mono-project.com/repo/debian wheezy main

  保存後運行 apt-get update ,可能會出現錯誤提示:

W: GPG error: http://download.mono-project.com wheezy Release: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY A6A19B38D3D831EF

  運行以下命令添加key:

sudo apt-key adv --recv-keys --keyserver keyserver.ubuntu.com A6A19B38D3D831EF

  再次運行 apt-get update ,更新完成後運行 apt-get install mono-complete 即可安裝最新版本的Mono,安裝完成後運行 mono -V 查看Mono版本

安裝Oracle Client

  1. 下載Oracle client   (oracle-instantclient11.2-basic-11.2.0.1.0-1.x86_64.rpm)http://www.oracle.com/technetwork/cn/topics/linuxx86-64soft-095635-zhs.html

    2. 安裝alien,和依賴包

    sudo apt-get install alien

    sudo apt-get install libaio1

   3. 使用alien吧rpm包轉換成deb包,並且安裝:

    sudo alien -i oracle-instantclient12.2-basic-12.2.0.1.0-1.x86_64.rpm

    4.安裝完後,類庫會放到 /usr/lib/oracle/版本號/client/lib/ ,需要做一個軟連接,否則Mono找不到需要的共用庫

    sudo ln -s /usr/lib/oracle/12.2/client64/lib/libclntsh.so.12.1 /usr/lib/oracle/12.2/client64/lib/libclntsh.so 

          5. 更新ldconfig設置:

    在 /etc/ld.so.conf.d目錄下新建 oracle-client.conf  , 輸入Oracle Client 類庫的路徑, /usr/lib/oracle/12.1/client/lib

    別忘了執行  sudo ldconfig

     6.在伺服器上執行:select userenv('language') from dual;  獲取伺服器的字元集

    查看客戶端字元集,在終端下執行:

    echo $NLS_LANG

     修改客戶端字元集:

    sudo gedit /etc/environment

    在environment 文件中增加以下內容:

    NLS_LANG="SIMPLIFIED CHINESE_CHINA.AL32UTF8"

    export NLS_LANG

    重新啟動操作系統即可。

 

修改程式

  1.PetaPoco源碼修改:

    PetaPoco報空對象引用 的錯誤,修改PetaPoco.cs中下麵代碼:

    public override void PreExecute(IDbCommand cmd) 

    { 

        //註掉下麵一行,修改為下麵的代碼。Command對象里不存在"BindByName"的屬性,此處會報錯 

        //cmd.GetType().GetProperty("BindByName").SetValue(cmd, true, null); 

       PropertyInfo bindByNameInfo = cmd.GetType ().GetProperty ("BindByName"); 

        if (bindByNameInfo!=null) { 

            bindByNameInfo.SetValue (cmd, true, null); 

         } 

    }

  2. 添加 System.Data.OracleClient.dll 引用

   3. 資料庫連接字元串修改為

     <add name="xxx" providerName="Oracle.ManagedDataAccess.Client" connectionString="Data Source=(DESCRIPTION=        (ADDRESS_LIST=(ADDRESS=    (PROTOCOL=TCP)(HOST=xxx)(PORT=1521)))        (CONNECT_DATA=(SERVICE_NAME=xxxx)));User Id=xxx;PassWord=xxx;" />

運行程式

  mono xxx.exe

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • shell腳本中的迴圈選擇語句用法詳解及實例。包括if、case、for、while、until、select、continue、break、shift、trap等。 ...
  • 什麼是動態鏈接庫?Windows下重要的幾個動態鏈接庫;DLL的使用優點; ...
  • 關於Linux Centos6.5的SSH預設埠修改的博客有一大堆,我在這裡就不啰嗦了,但是面對Centos 6.9,就會發現有一個巨坑; 修改iptables之後執行下麵的命令後; 會發現dport 修改失敗,埠號仍為22, 此時,你會很鬱悶的發現無論怎麼修改都不生效, 重點來了,我嘗試了無數 ...
  • 一、FastSocket課程介紹 .NET框架雖然微軟提供了socket通信的類庫,但是還有很多事情要自己處理,比如TCP協議需要處理分包、組包、粘包、維護連接列表等,UDP協議需要處理丟包、亂序,而且對於多連接併發,還要自己處理多線程等等。本期分享課程阿笨給大家帶來的是來源於github開源Soc ...
  • 介紹 一款優雅的博客園Android客戶端,Xamarin App,Material Design風格。如有意見反饋或bug提交,請加QQ群(181050206)交流. 項目地址 Github: "Cnblogs" 歡迎Fork,歡迎Star。 支持功能 登錄博客園 查看已發佈的博客 查看博文,新聞 ...
  • 為啥我要做這個東西了,是因為經常要用投影演示app ,現在有很多這樣的軟體可以把手機界面投到電腦上 ,但都要安裝,比如說360的手機助手,我又討厭安裝,於是就自己搗鼓了下 做了這個東西, 實現了以下簡單功能 1、屏幕獲取(因為是截圖方式獲取的,所以有點卡頓) 2、實現點擊功能,併在點擊的時候出現一個 ...
  • 給大家看個計算題,看看大家的算術能力。 0.1 +0.1 +0.1 - 0.3 等於幾? 大家可能會說這麼簡單的問題,是不是看不起我?肯定等於0啊。 如果大家直接算的是沒有問題的,但是如果用電腦呢? 見證奇跡的時刻到了,看代碼: 運行結果: 這是因為電腦的精度的問題,在電腦的內部存儲和運算的精 ...
  • 之前對於同步方法和使用async、await的非同步方法一直很迷惑。我覺得等待執行結果的非同步和同步方法有什麼區別嗎?他們的執行順序都是一樣的啊? 不是都需要等待執行結果嗎?今天翻了一下《C#高級編程》,才算搞清楚這裡面的差異,原來使用了async、await的非同步是不會阻塞線程的。 首先說說關於同步方 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...