Windows üzerinde alışık olduğumuz MSSQL kullanımını Linux üzerinde deneyimleme fırsatım oldu.
Amazon AWS üzerindeki denemelerimde %30 Maliyet kazancı sağlanabildiğini gördüm. "Ubuntu Server 16.04 LTS (HVM) With SQL Server 2017 Web" AMI üzerinden bir Ec2 instance üreterek işe başldım.
Başlangıç olarak test amaçlı 1CPU-2GB RAM t2.small bir makine ile başlamayı tercih ettim. Maliyet Ölçümü için s3 calculator ile baktığımızda 66.72$ Aylık(720saat) kullanım ücreti görüntüledim. Windows için 75.69$ olarak %10 fark olduğunu görüntüledim.
Linux Makina Kurulumu nasıl Yapılır ?
Amazon Console üzerinden Ec2 içerisinden Launch Instance seçeneğini kullanarak bir linux makina ayağa kaldırıyoruz. "Ubuntu Server 16.04 LTS (HVM) With SQL Server 2017 Web" olarak AWS Marketplace içerisinde bulabiliriz.
Linux üzerinde bağlantı nasıl sağlanır ?
PuttyGen aracılığı ile bağlantıyı sağlayabilirsiniz. Makina kurulumu sırasında size verilen .pem dosyasını kullanarak işlemi yapacaksınız. PuttyGen açtığınızda Load tıklayarak pem dosyasını verin. Public ve private key kayıtlarını sağlayın.
Belirleyeceğimiz şifre ile giriş yapacağız. Güçlü bir şifre belirleyin.
Herşey hazır olduğunda bağlantı için Putty.exe çalıştırın.
Puttgen içerisinde belirlediğimiz şifremizi burada kullanarak giriş yapıyoruz.
Ve giriş yapıldı. SQL çalışıyor mu kontrol edelim.
systemctl status mssql-server
Linux üzerinde MSSQL kurulumu nasıl yapılır ?
Öncelikle iki doküman size yardım olacaktır. SQL hazır olarak gelecektir (AWS EC2) Aşağıda linklerini paylaştım. Sqlcmd kullanımı için kurulumu yapıyoruz. Sql Agent aktif hale getiriyoruz.
sudo apt-get update
sudo apt-get install mssql-tools unixodbc-dev
sudo /opt/mssql/bin/mssql-conf set sqlagent.enabled true
sudo systemctl restart mssql-server
https://docs.microsoft.com/en-us/sql/linux/quickstart-install-connect-ubuntu?view=sql-server-2017
https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-setup-sql-agent?view=sql-server-2017
Linux MSSQL sa şifresi nasıl belirlenir ?
sudo systemctl stop mssql-server
sudo MSSQL_SA_PASSWORD=ŞİFRENİZ /opt/mssql/bin/mssql-conf set-sa-password
sudo systemctl start mssql-server
systemctl status mssql-server
Linux MSSQL yeni kullanıcı ekleme nasıl yapılır ?
Buradan sonrası sql query ile ilerleyebileceğiniz yerlerdir. Örnek olarak.
sqlcmd -U sa -P Şifreniz -q "CREATE LOGIN KullaniciAdi WITH PASSWORD = 'ŞİFRENİZ';GO;CREATE USER KullaniciAdi FOR LOGIN KullaniciAdi;GO"
Linux MSSQL S3 üzerinde Backup/Restore nasıl gerçekleştirilir ?
apt install awscli kurulumunu yaparak s3 üzerindeki bir dosyanızı makina içerisine indirebilirsiniz.
aws s3 cp s3://sqlbackup/yourdatabase.bak ./yourdatabase.bak
sqlcmd -U sa -P Şifreniz -q "USE [master];GO;RESTORE DATABASE [yourdatabase] FROM DISK = '/yourdatabase.bak' WITH MOVE 'yourdatabase' TO '/mssql/data/yourdatabase.mdf',MOVE 'yourdatabase_log' TO '/mssql/data/yourdatabase.ldf', REPLACE;"
Sonrasında GO diyerek işlemi tamamlıyoruz. Artık var olan veritabanımızı içeri aktardık. Buradan sonrasını SQL management üzerinden bağlanarak maintaince plan üreterek zamanlamaları planlayarak backupları yönetebilir duruma geliyoruz.
aws s3 sync ./ s3://sqlbackup şeklinde belirli bir klasördeki verilerin tamamını aktarabiliriz.
Düzenli S3 aktarımlı backup yönetimi için;
https://dev.to/lukebearl/ms-sql-server-backups-to-s3--on-linux-dan