1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        Ubuntu 10.10 源碼安裝MySQL 5.1.34

        發布時間:  2012/8/17 17:33:04

        最近將系統重新安裝了Ubuntu 10.10系統,需要重新編譯安裝Mysql,源碼版本是5.1.34

        很折騰,不知道10.10的系統改了些什么東西,裝軟件都這么不順利

        在這里把發生的問題都記錄一下:

        步驟如下:

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
        -
         

        1. 安裝Ubuntu 10.10下的編譯工具

        sudo apt-get install build-essentials

        安裝后gcc 和 g++ 的版本都是 (Ubuntu/Linaro 4.4.4-14ubuntu5) 4.4.5

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

        2. ./configure --prefix=/usr/local/mysql

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

        3. make

        在make時出錯,最后幾行如下:

        make[2]: *** [do_abi_check] Error 1

        make[2]: Leaving directory `/home/ice/Documents/software/mysql/src/mysql-5.1.34'

        make[1]: *** [abi_check] Error 2

        make[1]: Leaving directory `/home/ice/Documents/software/mysql/src/mysql-5.1.34'

        make: *** [all-recursive] Error 1

        參照 http://bugs.mysql.com/bug.php?id=52514 中對此問題的說明,將Makefile中最后面的do_abi_check注釋掉

        跳過ABI Check

        重新make成功

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

        4. sudo make install 順利通過

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

        5. 到目錄/usr/local/mysql下執行如下命令 (ice是我的用戶名)


        chown -R ice .

        chgrp -R ice .

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

        6. 到目錄/usr/local/bin 下 運行mysql_install_db --basedir=/usr/local/mysql \

        --datadir=/usr/local/mysql/data

        ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

        7. 切到目錄libexec下

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

        執行命令 ./mysqld 產生如下錯誤

        101215 10:09:07 [ERROR] Can't find messagefile '/usr/share/mysql/english/errmsg.sys'

        問題的原因,應該是自己沒有定義一個my.cnf配置文件,如果不給自己的配置文件,系統就會用默認的配置,然后就會產生上面的錯誤

        將源碼中的 support_files 文件夾下的 my_small.cnf 復制到 /etc/my.cnf下,并增加一個參數

        language = /usr/local/mysql/share/mysql/english

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

        運行 ./mysqld 還有錯:

        101215  2:25:47 [Warning] Can't create test file /var/lib/mysql/ice-ThinkPad-R400.lower-test

        101215  2:25:47 [Warning] Can't create test file /var/lib/mysql/ice-ThinkPad-R400.lower-test

        ./mysqld: Can't change dir to '/var/lib/mysql/' (Errcode: 2)

        101215  2:25:47 [ERROR] Aborting

        101215  2:25:47 [Note] ./mysqld: Shutdown complete

        未找到原因,查閱官方文檔http://dev.mysql.com/doc/refman/5.1/en/starting-server.html

        發現中間有這么一句話: When the mysqld server starts, it changes location to the data directory.

        所以估計上面的錯誤是因為沒有指定datadir參數,系統默認數據文件夾是在 /var/lib/mysql/ 的原故吧

        再一次運行命令 ./mysqld --datadir=/usr/local/mysql/data

        上面的錯誤沒有了

        將這個參數也加到 /etc/my.cnf 配置文件中

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

        運行 ./mysqld 發生如下錯誤

        101215 11:12:31 [ERROR] Can't start server : Bind on unix socket: No such file or directory

        101215 11:12:31 [ERROR] Do you already have another mysqld server running on socket: /var/run/mysqld/mysqld.sock ?

        101215 11:12:31 [ERROR] Aborting

        糾結,怎么不斷的有錯誤,繼續在網上搜索終于找到了問題的根源所在

        在Ubuntu下,還有一個這樣的配置文件 /etc/mysql/my.cnf

        文件中有下面幾行:

        user= mysql

        socket= /var/run/mysqld/mysqld.sock

        port= 3306

        basedir= /usr

        datadir= /var/lib/mysql

        tmpdir= /tmp

        這個配置文件是系統自己帶的,原來上面好多問題都是這個隱藏的配置文件在搞鬼,唉,折騰了好長時間,終于找到問題根源了!

        將/etc/mysql/my.cnf 改為 /etc/mysql/my.cnf.backup

        再次運行 ./mysqld

        101215 11:54:11 [Note] Event Scheduler: Loaded 0 events

        101215 11:54:11 [Note] ./mysqld: ready for connections.

        Version: '5.1.34'  socket: '/tmp/mysql.sock'  port: 3306  Source distribution

        ready for connections 終于成功了! 祝賀一下自己!

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

        注:這兩天又查了一些資料發現出現這么多問題的原因是由于gcc4.3升級到gcc4.4版本的改動,用gcc4.4編譯,不僅ABI_CHECK出現問題,安裝后執行mysql自帶的測試時還有一些測試通不過,將編譯器降為gcc4.3和g++4.3后,源碼安裝過程中就不會出現ABI_CHECK不通過的問題,編譯成功后能通過所有的測試

        .htm


        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线