6
มี.ค.

Cloud Servers?

ทุกวันนี้เราจะเห็นได้ว่า เทคโนโลยีของ Cloud หรือ Cloud Computing ได้เข้ามาเกี่ยวข้องกับชีวิตประจำวันของเรามากขึ้น ในอนาคตจะมีการเอา Cloud Computing ไปประยุกต์ใช้ในด้านต่างๆ จึงทำให้หน่วยงานหลายๆหน่วยงาน เริ่มให้ความสนใจกับระบบ Cloud มากขึ้น

คลาวด์ หรือ Cloud Computing คือการทำงานของ Server ขนาดใหญ่ ที่ทำงานด้วย Sever หลายๆ เครื่อง โดยแบ่งชั้นการประมวลผลออกจากชั้นเก็บข้อมูล เป็นการร่วมกันทำงานของ Server หลายๆ เครื่อง มีผลดีคือเมื่อ Server ใด Sever หนึ่งเกิดความเสียหายขึ้นก็จะไม่ส่งผลกับการใช้งานของผู้ใช้บริการ เพราะระบบจะทำการย้ายไปทำงานในเครื่องใหม่โดยอัตโนมัติ ซึ่งก็แสดงถึงความปลอดภัยของข้อมูลของผู้ใช้บริการนั่นเอง

 

ข้อดีของบริการ Cloud Server มีดังนี้

ความยืดหยุ่น : สามารถดึงทรัพยากรเพิ่มเติมมาใช้ได้เมื่อต้องการ

คุ้มค่าใช้จ่าย : คิดค่าบริการเมื่อมีการใช้งาน ผู้ใช้บริการจ่ายค่าบริการตามจำนวนค่าใช้งานจริงในแต่ละช่วงเวลาเท่านั้น

ติดตั้งง่าย : Cloud Server ไม่มีการตั้งค่าเริ่มต้นที่วุ่นวายมากนัก

เชื่อถือได้ : เพราะมี Server สำหรับให้บริการอยู่หลายตัว ถ้าตัวไหนเกิดมีปัญหาขึ้นมา แหล่งทรัพยากรก็จะย้ายไป Server อื่นทันทีโดยไม่กระทบต่อการใช้งานของผู้ใช้บริการ

ซึ่งในปัจจุบัน Cloud ได้เริ่มเข้ามามีบทบาทในการใช้งาน Web Hosting มากขึ้น อาจเป็นเพราะ Cloud สามารถช่วยประหยัดค่าใช้จ่ายในด้านการลงทุนซื้อ Server ได้ สามารถเลือกจ่ายค่าบริการเท่าที่ทางองค์กรเลือกใช้ และยังมีบริการให้เลือกใช้อย่างหลากหลาย ตัวอย่างเช่น Web Site , VM หรือ VPS , Mobile Service , Storage , Etc.

 

24
พ.ย.

Container : รากฐานของระบบ Cloud

สำหรับใครที่เป็นสาย IT หรือ CXO (Cheif Experience Officer) คงเคยได้ยินเรื่องเกี่ยวกับ Docker และ Containerization กันมาบ้างแหละ แต่ถ้าถามว่า Docker และ Container คืออะไร แล้วจะมามีบทบาทเพิ่มศักยภาพให้ Virtual และ Cloud Infrastructure ของได้อย่างไร

ช่วงราวๆ ปี 1970 IBM ได้คิดค้น VM/370 Operating System ขึ้นมา ทำให้สามารถแยกส่วนการทำงานทางกายภาพและ Software ของ Mainframe Computer ได้ คือ ทำให้พวก Instance ของ OS หรือ VM รันได้ใน Environment ส่วนตัว สำหรับ Application และ User แต่ละรายออกจากกัน นอกจาก VM จะช่วยเสริมประสิทธิภาพการทำงานของ Mainframe แล้วยังทำให้การบริหารจัดการง่ายขึ้นอีกด้วย

และในที่สุด เทคโนโลยี Virtualization ก็แพร่หลายมาสู่ Intel และ PC ซึ่งเดิมถูกใช้งานสำหรับ Compatibility เช่น ระบบ DOS/Windows subsystem implemented in OS/2 2.0 เมื่อปี 1992

ต่อมาในปี 1999 VMware ได้เปิดตัวผลิตภัณฑ์ชิ้นแรก คือ VMware 1.0 สำหรับ Linux เพื่อให้ Windows และ Windows Application สามารถรัน Desktop Version ของ OS ได้ เนื่องจากในช่วงเวลานั้น Windows ยังขาด native apps อยู่หลายตัว ทำให้ VMware กลายมาเป็น Tools ยอดนิยมสำหรับ Software Developer ที่ต้องการ Code จาก Running Environment เผื่อในกรณีที่ Development VM เกิดผิดพลาดขึ้นมา OS จะได้ไม่ล่มไปทั้งระบบ

เมื่อเข้าสู่ยุค 2000 Client-server ก็เติบโตขึ้นอย่างรวดเร็วจน Data Center เต็มไปด้วย Server

และด้วยผลิตภัณฑ์จาก VMware ทั้ง ESX hypervisor, Xen, Hyper-V และ KVM ทำให้ x86 System ทั้งหลายกลายมาเป็น Virtual Machine กันเสียเยอะแยะ เม็ดเงินที่ต้องจ่ายเพื่อทำ Server และเป็นเจ้าของ Data Center จึงลดลงจนน่าตกใจ ผลลัพธ์ คือ จาก Physical Server หลายพันเครื่อง ตอนนี้เหลือเครื่อง Host สำหรับบรรจุ Virtual Machine เพียงไม่กี่เครื่องเท่านั้น

ซึ่ง Hypervisor และ Virtual Infrastructure นี้เองที่ผลักดันให้ Data Center และบริการ Publice Cloud แบบ IaaS (Infrastructure as a Service) เติบโตมาได้จนถึงทุกวันนี้

ในปัจจุบัน Public Cloud เช่น AWS (Amazon Web Service) และ Microsoft Azure จะเรียกเก็บเงินเป็นรายชั่วโมงที่ VM เปิดใช้งาน โดยคิดในส่วนของการใช้งาน Virtual cpus (vCPUs) ซึ่งเป็น Virtualization ส่วนหนึ่งของ Host CPU core

VM คือ แหล่ง Instance ทั้งหมดของ OS โดยต้องมี Kernel และ Device Driver ซึ่งเข้ากันได้กับ VM เครื่องอื่นๆ ที่ใช้ Hypervisor ร่วมกัน VM มีข้อดีด้านความสามารถในการย้าย System และ App ภายในจาก Physical ไปยัง Virtual ได้โดยไม่กระทบต่อโครงสร้างพื้นฐานของ Environment ที่มีอยู่ แต่ VM ก็กิน Resource เปลืองมาก โดยเฉพาะในส่วนของ Memory และ CPU intensive workloads อย่าง Database

ทั้งนี้ การใช้งาน VM ในระดับ Private และ Public Cloud หมายความว่า Workload จาก VM แบบ on-premise หลายเครื่อง จะถูกย้ายขึ้นไปบน Cloud กันหมด ซึ่งอาจเกิดปัญหา Scalability และเพื่อเป็นการแก้ปัญหาดังกล่าว Container จึงเข้ามามีบทบาท

Container คล้ายกับ VM ในด้านการสร้างพื้นที่เฉพาะสำหรับ Application โดยมีทรัพยากรแยกออกจากกัน ไม่ว่าจะเป็นพื้นที่สำหรับติดตั้ง, Memory และพื้นที่เก็บไฟล์ เพราะเหตุนี้ Container จึงสามารถมี Sysadmin และกลุ่มของ User ส่วนตัวเฉพาะแต่ละ Container ได้ แต่ที่ไม่เหมือนกับ VM ก็คือ Container ไม่ได้รัน Instance หรือ Image ของ OS อย่างสมบูรณ์ ด้วย Kernels, Drivers, และ Libraries ที่แชร์ร่วมกัน และไม่ว่า Container จะมีจำนวนมากแค่ไหน ก็สามารถรันได้บน Single OS เดียวกัน และมีขนาดเล็กนิดเดียว เมื่อเทียบกับ VM

ภายในหนึ่ง Container จะมีเพียง Application และ Setting กับ Storage ที่จำเป็นสำหรับการทำงานของ Application เท่านั้น ซึ่งบางครั้ง Concept นี้จะถูกเรียกว่า JeOS “Just enough OS”

ด้วยความที่ Container สามารถโอนถ่าย Libraries และ Patches จาก Host เมื่อ Host ของ Container อัพเดท Libraries พวก Container ทั้งหมดที่อยู่ใน Host ก็จะอัพเดท Libraries ไปด้วย จึงเรียกได้ว่า Container หรือ Virtual Environment ที่อยู่บน Host เดียวกันใช้งาน OS เวอร์ชั่นเดียวกันทั้งหมด

ทางด้านการทำงาน Container นั้นต้องการ Host OS หรือ Containerization Platform อย่าง LXC กับ Docker แตกต่างจาก VM ที่รันบน Hypervisor เพราะฉะนั้น Containerization จึงถูกพูดถึงในฐานะ Virtualization ในระดับ OS (Operating System-level Virtualization) โดย Linux containerization host จะรัน Linux containers ส่วน Windows containerization host ก็รัน Windows containers และเพราะ Container หลายตัวสามารถรันได้ด้วย Single Instance ของ OS การจะให้ Container Host กลายมาเป็น Single VM จึงสามารถทำได้เช่นกัน

ตอนนี้เราก็มาถึง Containerization Technology ที่กำลังเป็นที่สนใจกันแล้ว นั่นก็คือ Docker โดย Containerization Engine จริงๆ ของ Docker ใน Linux OS คือ LXC

Docker เป็น Containerization Technology ที่โดดเด่นด้วยการทำให้เราสามารถรวม Application ซับซ้อนทั้งหลายเป็นแพ็คเกจเอาไว้ แล้วอัพโหลดขึ้นที่เก็บไฟล์สาธารณะ จากนั้นก็ดาวน์โหลดมาติดตั้งใน Public หรือ Private Cloud ที่มี OS ซึ่งรัน Docker Engine และ Containerization Platform อยู่ ซึ่งเป็นวิธีการเดียวกันกับที่เราโหลดแอพฯ จาก App Store มาลงสมาร์ทโฟนหรือแท็บเล็ตนั่นแหละ

การย้าย Docker ไป Host อื่นก็สามารถทำได้ไม่ต่างกับการย้าย VM  แถมยังเร็วกว่าด้วยซ้ำ ส่วนเรื่องการ Clustering ข้อมูล Docker จะใช้ Swarm เป็นตัวจัดการไฟล์

สรุปแล้ว การมาถึงของ Container Technology ทำให้การพึ่งพา VM ลดน้อยลง เพราะ Container ได้นำเสนอทางเลือกประหยัดค่าใช้จ่ายด้าน Cloud Computing โดยเฉพาะในระดับ Hyperscale ได้อย่างน่าดึงดูดใจ ให้เหล่า CXO ต้องกลับไปคิดทบทวนเรื่องปรับโครงสร้างระบบและเปลี่ยนมาใช้งาน Docker กันสักที

18
ต.ค.

OpenStack ในสายตาผู้เชี่ยวชาญ 6 ปีที่ผ่านมาเป็นอย่างไร ?

หลังจากการเปิดตัวของ OpenStack ต้องบอกว่าได้รับกระแสการตอบรับที่ดีมาก แต่ว่าจำนวนคนที่นำไปใช้งานจริงๆ กลับน้อยกว่ามาก แล้วอะไรคือสาเหตุ ใช้งานยาก ? ยังไม่เหมาะ? หรือยังไม่สมบูรณ์? ถึงแม้ Rackspace และ NASA ร่วมกันพัฒนา OpenStack แล้วเปิดให้ใช้งานในฐานะ Open Source Cloud Platform เป็นที่เรียบร้อยแต่ทิศทางการเติบโตก็ยังไม่โตเท่าที่ควร หรือว่ากันง่ายๆคือยังไม่รู้ว่าอนาคตของ OpenStack จะไปจบที่ทิศทางไหนนั่นเอง

 

Brian Kirsch จาก  Milwaukee Area Technical College

ได้กล่าวไว้ว่า “Open source cloud creation platform อย่าง OpenStack มีขีดความสามารถทำอะไรได้มากและถูกออกแบบขึ้นมาเพื่อ Cloud โดยเฉพาะบริษัท Hosting หรือจะคู่แข่งทางเทคโนโลยี หลายๆ บริษัทที่จะก้าวขึ้นเป็นที่ 1 ในด้านเทคโนโลยีล้วนต้องมีส่วนเกี่ยวข้องกับ OpenStack ไม่ว่าทางใดก็ทางหนึ่ง และตัว Platform ของ OpenStack เองถือว่ามีความโดดเด่นอยู่หลายด้านสำหรับ Open Source อย่างไรก็ตาม OpenStack ไม่ได้รับความสนใจในวงกว้างที่จริงแล้วมันเรียกได้เลยว่ามีคนนำไปใช้งานค่อนข้างน้อย เพราะจุดอ่อนข้อใหญ่ของ OpenStack คือยากต่อการติดตั้งและการใช้งาน ถ้าจะมีถามว่ายากในระดับไหน ก็คงตอบได้ว่าขึ้นอยู่กับพื้นฐานประสบการณ์และการฝึกฝนของผู้ใช้ ถึงแม้จะมี Online Guide ที่ค่อนข้างครอบคลุม แต่ก็ยังต้องการสารพัด Command Line ที่ถูกต้องอีกหลายขั้นตอน รวมทั้ง Input ต่างๆ สำหรับการติดตั้งและใช้งาน OpenStack และขั้นตอนซับซ้อนพวกนี้จะไม่ส่งผลอะไรกับฟีเจอร์ของ OpenStack แต่กระทบเข้าเต็มๆ กับอัตราการเลือกใช้งานในวงการ IT เราต้องการสร้างสิ่งที่ยิ่งใหญ่จากทรัพยากรจำนวนน้อย และการที่ต้องใช้คนกับเวลาจำนวนมากหมดไปกับการติดตั้ง OpenStack แลกกับการประหยัดงบประมาณของระบบปฏิบัติการสำหรับใช้งานบน Cloud ที่จริงแล้วมันเกิดความคุ้มค่าจริงเหรอ? ใครๆ ต่างก็อยากประหยัดค่า Lincense ด้วยการหันมาหา Open source กันทั้งนั้น แต่สุดท้ายแล้วมันจะเหมือนในของกรณี Linux สำหรับ Desktop ที่ทราบกันว่าผลสุดท้ายออกมาอย่างไร….

Brian Kirsch  ได้กล่าวไว้ว่า OpenStack นั้นยังไม่เหมาะสำหรับผู้ใช้งานทางด้าน ITเพราะมันควรจะจะง่ายต่อการใช้งาน ถ้า OpenStack  อยากจะเติบโตไปเป็นอนาคตของเทคโนโลยีจะต้องพัฒนาไม่ใช่การไปนั่งเขียนเอกสารอธิบายวิธีการใช้งานให้กับผู้ที่สนใจ

3
ต.ค.

เพิ่มประสิทธิภาพให้องค์กรก้าวไกล ด้วย Private Cloud

อย่างที่หลายคนรู้ หรือได้ยินผ่านหูมาบ้างเกี่ยวกับ ระบบ Cloud Computing ว่าคือระบบที่ช่วยพวกเราจัดเก็บข้อมูลได้เป็นระเบียบ พร้อมทั้งมีความปลอดภัยสูง โดยผ่านผู้ให้บริการเกี่ยวกับ Cloud ที่เชื่อถือได้ แถมยังมีความเชี่ยวชาญ และระบบ Cloud เองยังมีหลายประเภทแยกย่อยออกไป ซึ่งเราจะหยิบยกมาคุยกันคือ Private Cloud ซึ่งคือหนึ่งในระบบ Cloud ที่เริ่มนิยมใช้กันมากขึ้น

Private Cloud คือ ระบบที่ทำงานอยู่บนระบบ Cloud และได้รับการบริหารจัดการโดยบริษัท เพื่อการใช้งานเพียงแค่ในองค์กรเท่านั้น ซึ่งผู้ให้บริการ และผู้ใช้บริการจะสามารถควบคุมและปรับปรุงในเรื่องของระบบความปลอดภัยได้ด้วยตนเอง ซึ่งถือว่าเป็นจุดเด่นอย่างหนึ่งของระบบ Cloud เลยก็ว่าได้

หากจะพูดถึงข้อดีของ Private Cloud ก็มีหลายอย่างด้วยกัน อาทิ การมีความปลอดภัยสูง เนื่องจากเป็นการจัดเก็บระบบข้อมูลที่เป็นความลับขององค์กร ทำให้มั่นใจได้ว่าข้อมูลไม่เกิดการรั่วไหล รวมไปถึงเรายังสามารถควบคุมระบบได้ง่าย ทั้งยังสามารถควบคุมค่าใช้จ่ายให้อยู่ในขอบเขตที่ต้องการได้อีกด้วย

โดยในปัจจุบันมีหน่วยงานทั้งขนาดเล็กและขนาดใหญ่ที่ให้ความสนใจใช้บริการ Private Cloud นี้ เพราะสะดวกกับการจัดการข้อมูลจำนวนมหาศาลให้เป็นระเบียบมากขึ้น โดยที่สามารถโฟกัสกับงานหลักได้โดยไม่ต้องกังวลเรื่องข้อมูล ซึ่งจะส่งผลให้การทำงานภายในองค์กรมีประสิทธิภาพมากยิ่งขึ้น

นอกจากนั้น Private Cloud ยังสามารถทำงานร่วมกับ Hybrid Cloud ที่ถือว่าเป็นระบบที่ผสมผสานระหว่าง Private Cloud และ Public Cloud เข้าด้วยกัน ทำให้เราสามารถทำงานเชื่อมต่อกันได้ทั้ง Private Cloud และ Public Cloud ซึ่งสามารถสลับไปมาตามความต้องการได้

เทคโนโลยีก้าวไกลขึ้นขนาดนี้แล้ว หากไม่อยากตกเป็นกลุ่มที่ล้าหลัง ก็ต้องหาตัวช่วยโดยการใช้ประโยชน์จากเทคโนโลยีให้ได้มากที่สุด เพื่อความก้าวหน้าขององค์กร และประสิทธิภาพที่ดีขึ้นของบริษัท ซึ่ง Private Cloud ก็เป็นตัวเลือกหนึ่งที่ดีเช่นกัน