iT邦幫忙

5

SQL Server 2017 for Linux

賽門 2017-07-19 11:41:1828063 瀏覽

自從生病以來,有好一陣子沒來iT邦發文了,最近微軟推出SQL Server 2017,也把SQL Server for Linux推進一個新的版次,長期關注Linux及開源趨勢,我注意到雖然SQL Server推出Linux版本已經有段不短的時日,但,似乎很少有討論SQL Server for Linux的文章出現,或許因為還是以For Windows為主流討論版塊,Linux社群向來對微軟沒好臉色,以及微軟一直算是封閉系統跟開源扯不上關係,等等因素,SQL Server for Linux的討論文章一直很少見到。

好了,前言表過,讓我們來看看SQL Server 2017 for Linux吧。
首先,SQL Server 2017 for Linux不是免費的產品。所以安裝的是評估版

我個人比較喜好的Linux發行是CentOS所以下載新版CentOS來做為SQL Server for Linux的平台。微軟建議的Linux平台是RHELUbuntuSuSE。但,基本上,由RHEL衍生的Linux發行,只要Kernel是是穩定版本都可以安裝。
http://ithelp.ithome.com.tw/upload/images/20170719/20017649rkxenlcZfT.png
其實,比較重要的是安裝的Repo及套件。我比較傾向於安裝開發工具套件。
我用Windwos 8.1的Hyper-V 3.0來安裝CentOS,Hyper-V的設定為:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649rYzQUjL9Ov.png
CentOS的主要安裝設置畫面如下:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649HN0AmQRCXw.png
對於安裝套件,我是選用"用來進行開發和建立的工作站":
http://ithelp.ithome.com.tw/upload/images/20170719/20017649ZSJm4XekKF.png
CentOS的安裝過程我就簡略了,總之,安裝完成後,打開Mozilla,進入MIcrosoft的SQL Server網頁,再打開Linux終端機,為了簡化SQL Server for Linux的安裝過程,我直接以root帳號登入系統,這樣少了很多sudo的麻煩。
我是遵照RHEL的安裝過程來在CentOS中安裝:

  1. 以Root帳號登入。
  2. 打開Mozilla再連結到SQL Server for Linux_RHEL的網頁。
  3. 再打開終端機,輸入以下指令進行SQL Server 2017 for Linux的安裝:
curl https://packages.microsoft.com/config/rhel/7/mssql-server.repo > /etc/yum.repos.d/mssql-server.repo    >> 抓取SQL Server的Repo
yum install -y mssql-server    >>用yum安裝SQL Server套件
/opt/mssql/bin/mssql-conf setup    >>進行SQL Server的設置
systemctl status mssql-server     >>檢查SQL Server的啟動狀態
sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent    >>在防火墻打開SQL Server的1433埠
sudo firewall-cmd --reload     >>重新載入防火墻,以啟動SQL Server 1433 埠

以下是執行上述指令的過程畫面截圖:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649xz3p5TbCyk.png
http://ithelp.ithome.com.tw/upload/images/20170719/20017649yrlg6EJwar.png
http://ithelp.ithome.com.tw/upload/images/20170719/20017649mqshjSyIbQ.png
下圖為設定SQL Server的過程,請注意提供了設置SA帳號的密碼的過程,這是SSMS可用來登入的惟一途徑。另外,可以看到是180天評估版本,但設定好會看到只有175天...XD
http://ithelp.ithome.com.tw/upload/images/20170719/200176495VQCPxJWow.png
http://ithelp.ithome.com.tw/upload/images/20170719/20017649hv1pmLXwwO.png
最後,檢查SQL Server有無順利正常啟動,以及設置防火墻:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649doF6DUFPrO.png
看看CentOS的IP位址,SSMS要用這個位址來連線:
http://ithelp.ithome.com.tw/upload/images/20170719/200176490Gy5Z5Ofv2.png
打開SSMS,在連線對話窗如下輸入連線訊息,請注意是輸入IP及SA的帳號密碼:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649adEfz0gy8a.png
連線後,SSMS如下圖:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649NqVOxudHsx.png
我們仔細看物件總管:
http://ithelp.ithome.com.tw/upload/images/20170719/20017649rT5NjJ2bl9.png
可以看到SQL Server Agent是在關閉狀態,而且可以看到Agent XP's disable.
我們要先把Agent XP's啟動, 才能啟用SQL Server Agent。而且,還要另外安裝SQL Server Agent套件。這部份我以後再來貼文討論了。如果想先瞭解SQL Server Agent在SQL Server for Linux上的啟用,可以參考:
Install SQL Server Agent on Linux
今天就先談到這裏,下回再見。
/images/emoticon/emoticon41.gif

文章同步發表在點部落
原來, 之前已發表過了...SQL Server for Linux on Open SuSE Platform


圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中
0
尼克
iT邦大師 1 級 ‧ 2017-07-19 17:31:35

賽大:
好好保重呀!
不過看來,Linux 安裝還是需要好多步驟。
太久沒有玩Linux/Unix了,所以有點感覺繁瑣了多。

賽門 iT邦超人 1 級 ‧ 2017-07-19 17:34:01 檢舉

/images/emoticon/emoticon39.gif

0
海綿寶寶
iT邦大神 1 級 ‧ 2017-07-20 09:50:10

SQL Server for Linux 還好
因為 MySQL/Postgre/MariaDB 一直都支援 Windows/Linux

我比較擔心的是
有一天看到 Mac OSX for PC
/images/emoticon/emoticon27.gif

fillano iT邦超人 1 級 ‧ 2017-07-20 10:04:44 檢舉

iOS for ARM或是iOS for MIPS之類會更驚人

賽門 iT邦超人 1 級 ‧ 2017-07-20 10:08:51 檢舉

Mac OSX for PC....
/images/emoticon/emoticon36.gif
要這樣搞,我直接去Linux陣營,拒絕MacOSX,對Windows控來說,MacOS比Linux更難以操作。

我不要哩
/images/emoticon/emoticon70.gif

0
fillano
iT邦超人 1 級 ‧ 2017-07-20 10:02:49

在Mac用Docker來裝也還蠻簡便...

賽門 iT邦超人 1 級 ‧ 2017-07-20 10:06:26 檢舉

嗯嗯,請費大公寫篇文來分享經驗,用Mac的邦友似乎不常來分享Mac上的訊息。
/images/emoticon/emoticon31.gif

太好了
我一直搞不清楚 Docker 是什麼..
甚實我連 Hyper-V 都不清楚
還停留在 VMWare/VirtualBox 的年代
/images/emoticon/emoticon16.gif

fillano iT邦超人 1 級 ‧ 2017-07-20 10:32:43 檢舉

也不用什麼經驗啦,根據微軟網站上的說明執行就好了XD

我要留言

立即登入留言