รู้จัก OpenStack

คุณรู้จัก OpenStack มากน้อยแค่ไหน แล้วรู้สึกไหมว่า ในยุค 4.0 นี้ เราเห็นคำว่า OpenStack ผ่านตามากมายจากหลายที่ นั่นเพราะเป็นเทคโนโลยี ที่กำลังมาแรงในขณะนี้ สำหรับใครที่ยังไม่มีความรู้ในเรื่องของ OpenStack เลยว่ามันคืออะไร วันนี้เราจะพาไปทำความรู้จัก เพื่อเป็นประโยชน์ในธุรกิจของตัวคุณเอง

ปัจจุบัน OpenStack ได้รับความนิยมมากขึ้นเรื่อยๆ อย่างกว้างขวางจากกว่า 250 องค์กรใน 130 ประเทศทั่วโลก ในฐานะ Open Source สำหรับ Private Cloud แต่อะไรทำให้ OpenStack มีความโดดเด่นเกินหน้าเกินตาคู่แข่งรายอื่นอย่าง Amazon EC2 กันล่ะ? บทความนี้จะพาคุณไปทำความรู้จักกับ OpenStack และเปิดเผยองค์ประกอบเด่นๆ ของมันกัน

OpenStack ในฐานะแพลตฟอร์มแบบ Open source

NASA และ Rackspace เป็นผู้เริ่มต้นพัฒนา OpenStack ก่อนจะเปิดเป็น Open source ให้เหล่าโปรแกรมเมอร์สามารถนำไปพัฒนาต่อได้ตามต้องการ โดยตรวจสอบ Source code ได้ทาง GitHub ทั้งนี้พวกโปรแกรมเมอร์ผู้พัฒนาระบบ OpenStack เองก็ทำงานให้กับองค์กรใหญ่ที่นำ OpenStack ไปใช้ด้วยเหมือนกัน เช่น Rackspace และ PayPal เป็นต้น

นอกจากนี้ ยังมีโปรเจ็คเกี่ยวกับ OpenStack อีกหลายโครงการ ซึ่งส่วนมากก็เป็นโปรเจ็คเฉพาะด้าน เช่น การติดตั้งแบบ bare-metal ผู้ที่สนใจจะเรียนรู้เกี่ยวกับการใช้งาน OpenStack หรือจะทดลองใช้ ทาง OpenStack ก็มี Development Version ให้ลองเล่นกันได้โดยนำไปติดตั้งบน Ubuntu Linux หรือจะใช้ OpenStack Autopilot wizard ในการสั่ง Deploy ก็ได้ ส่วน Source code ก็ไม่จำเป็น เพราะ OpenStack สามารถหาได้จาก Python package โดยใช้ Tools ชื่อ apt-get ในการติดตั้ง

รู้จัก Ecosystem ของ OpenStack

สิ่งที่เหมือนกันของ OpenStack กับ Amazon EC2 คือ ผู้ใช้สามารถ Provision VM จาก dashboard หรือ API ได้ แต่ข้อแตกต่างหลักๆ นอกจากเรื่องที่ OpenStack เป็นบริการฟรี คือ Amazon EC2 เป็นบริการ Public Cloud เท่านั้น ส่วน OpenStack ผู้ใช้สามารถเลือกได้ว่าจะใช้เป็นบริการ Private Cloud ของ OpenStack เอง หรือจะสมัครไปใช้ Public Cloud จากตัวแทนผู้ให้บริการของ OpenStack ก็ได้

OpenStack ในความจริงไม่ใช่ Hypervisor แต่ OpenStack เป็นโครงสร้างที่ถูกสร้างขึ้นมาเพื่อทำงานร่วมกับ Hypervisor ที่แตกต่างกันหลายๆ เครื่อง โดย User สามารถเลือกได้ว่าจะ Deploy Hypervisor บนตัวเครื่อง (machine) หรือบน OS ที่ built-in มากับ Hypervisor เช่น Linux KVM เป็นต้น นอกจากนี้ OpenStack ยังทำให้ User สามารถนำ VM ไปติดตั้งบน Bare-Metal Server (เซิร์ฟเวอร์สำหรับผู้ใช้คนเดียว) ได้อีกด้วย

Component หลักของ OpenStack

  • Horizon (Dashboard) : เป็น User Interface (UI) แบบ Web-based
  • Nova (Compute) : ประกอบด้วย Controller และ Compute Nodes ที่ดึง VM image มาจาก OpenStack image service และสร้าง VM บนเซิร์ฟเวอร์ที่เราต้องการ โดยมี APIs ที่แตกต่างกันตามแต่ Platforms เช่น XenAPI, VMwareAPI, libvirt for Linux KVM (QEMU), Amazon EC2, และ Microsoft Hyper-V เป็นต้น
  • Neutron (Networking) : สำหรับสร้าง Virtual Network และ Network Interface อีกทั้งยังทำหน้าที่เชื่อมต่อกับ Networking Products จากตัวแทนผู้ให้บริการอื่นๆ
  • Swift (Object storage) : มีหลักการทำงานเหมือน Amazon S3 โดยจะบันทึกข้อมูลแบบเดี่ยว อย่าง Image เก็บไว้โดยใช้ระบบ REST Web service
  • Cinder (Block storage) : คล้ายกับ Swift โดยจะเก็บ disk file ต่างๆ เช่น Log และเปิดให้เราสามารถเพิ่มเติมข้อมูลเข้าไปได้ ในขณะที่ Swift จะให้เก็บแทนที่ของเดิมเท่านั้น
  • Keystone (identity storage) : เป็นตัวคำสั่งที่เปิดให้ User และ Process สามารถเข้าถึง Tools ต่างๆ ของ OpenStack ได้โดยสร้าง Autentication Token ขึ้นมา
  • Glance (Image service) : เป็นตัวหลักของ OpenStack ในฐานะ Cloud Operating System คือ การสร้าง VM image ขึ้นมา โดย Glance คือแคตตาล็อครวม VM ที่เราอัพโหลดเอาไว้และเปิดให้ใช้กันภายในองค์กร
  • Trove (database server) : เป็นตัวสนับสนุนการทำงานของ Database ที่ต่างกัน

นอกจากนี้ Component พวกนี้ของ OpenStack ยังใช้ MySQL database ที่หลากหลาย สามารถทำงานร่วมกับ Python รวมทั้งใช้ Command line interface ของ Python ได้อีกด้วย ตัวอย่างเช่น

คำสั่งดาวน์โหลด Keystone จากเซิร์ฟเวอร์ Linux ที่เก็บข้อมูลเอาไว้แบบ Public

apt-get install keystone python-keystoneclient

คำสั่งสร้าง User บน Keystone

keystone user-create –name Sam –description “Sam”

คำสั่งลิสต์ชื่อ VM images ด้วย Nova

nova image-list

คำสั่งเปิด Python Shell ก็ทำได้ง่ายๆ แค่พิมพ์ Python แล้วตามด้วย

from keystoneclient.v2_0 import client

หรือถ้าใครไม่คล่อง Python CLI (Command Line Interface) จะสลับไปใช้ Dashboard แบบคลิกก็ได้เหมือนกัน

นิยามใหม่ OpenStack Cloud

ถ้าพูดถึง Public Cloud เราก็คงนึกถึง Amazon Web Service (AWS) เพราะเป็นอันดับต้นๆ ของตลาด แต่ถ้าพูดถึง OpenStack เราก็จะนึกถึง Private Cloud ที่รองรับการทำงาน Private Cloud ได้ดีที่สุดในเวลานี้

โดยอาจกล่าวได้เลยว่าไม่มี Cloud Technology Platform ใดๆ ที่จะได้รับการสนับสนุนได้มากเท่า OpenStack ซึ่ง OpenStack นั้นเกิดมาจากการร่วมมือกันของ NASA และ Rackspace ในปี 2010 ก่อนที่จะมีการเติบโตขึ้นในฐานะ Open source ซึ่งมีผู้ให้การสนับสนุนมากมาย ทั้ง HP, IBM, Intel, Cisco, Dell, EMC, VMware, Symantec, Huawei, และ Yahoo

ใครใช้ OpenStack บ้าง?

          ผู้ให้การสนับสนุนจำนวนมากเหล่านี้ เป็นเพียงแค่ครึ่งหนึ่งของจำนวนผู้ใช้งาน OpenStack เท่านั้น ซึ่งภายในงาน OpenStack Summit ที่ Vancouver ที่ผ่านมา ผู้ค้าระดับโลกอย่าง Walmart ได้ออกมาพูดถึงการใช้งาน OpenStack กับระบบการจัดการ Ecommerce ว่าสามารถสร้างความสำเร็จมหาศาลได้อย่างไร นอกจากนี้ OpenStack ยังเป็นเบื้องหลังความสำเร็จของทั้ง eBay, Paypal, Comcast, Time Warner Cable และ Bestbuy ส่วนทาง NASA เองก็ถือว่าเป็นอีกหนึ่งสาวกผู้ที่กำลังใช้ OpenStack เป็นรากฐานพัฒนาเทคโนโลยีพามนุษย์ไปสู่ดาวอังคารนั่นเอง

เมื่อเราพอจะมองเห็นภาพกว้างๆ แล้วว่า OpenStack ถูกใช้โดยใครและใช้ทำอะไรบ้างแล้วนั้น ต่อมาก็จะต้องมาทำความเข้าใจกันหน่อยว่าแท้จริงแล้ว OpenStack ไม่ใช่ Homogeneous Cloud Product หรือผลิตภัณฑ์ Cloud ที่อยู่ภายใต้ผู้ให้บริการรายเดียวแบบเสร็จสรรพ ตั้งแต่ Hypervisor ยัน Management Layer (* อ้างอิงจาก http://www.bmc.com/blogs/what-price-homogeneity/) และ OpenStack ก็ไม่ใช่ผลิตภัณฑ์ Virtualization Hypervisor แต่อย่างใด

OpenStack นั้นเป็นเพียงแพลตฟอร์มผสานการทำงาน หรือ Integration Platform เท่านั้น โดย OpenStack จะเป็น Framework ที่มาพร้อมกับ API และ Tool สำหรับ Cloud Service พวก Product และ Technology ต่างๆ จะถูก Integrate และ Deploy ภายใน Framework นี้ เพื่อสร้าง OpenStack Cloud ขึ้นมา

ผู้ให้บริการบิดเบือนความหมายของ Cloud

ความหมายที่แท้จริงของ Cloud ได้ถูกบิดเบือนไปโดยเหล่าผู้ให้บริการ เพื่อให้เข้ากับจุดประสงค์การขายสินค้าของตน และสำหรับ Cloud ของ OpenStack นั้น จะขอยึดเอาตามคำจำกัดความจาก Amandeep Singh Juneja ผู้เป็น Senior Director ด้าน Cloud Engineering ที่ Walmart Labs คือ “Cloud นำมาซึ่งความยืนหยุ่นและการทำงานอย่างต่อเนื่องของระบบ Infrastructure”

ทั้งนี้ทั้งนั้นทาง OpenStack เองก็ได้นำเสนอ Framework ที่จะทำให้ ระบบ Infrastructure ทำงานได้อย่างต่อเนื่องและยืดหยุ่นเช่นเดียวกัน

นิยามใหม่ของ OpenStack Cloud

แรกเริ่มเดิมที OpenStack มีอยู่ 2 โปรเจ็กต์ได้แก่ Nova Compute Project และ Swift Storage ซึ่ง Nova จะทำให้ Cloud Operator สามารถเลือกการ Deploy ได้จาก Hypervisor และ Virtualization Technology หลายๆ แบบ ไม่ว่าจะ ESX ของ VMware, Open Source อย่าง KVM และ Xen Hypervisor หรือกระทั้ง Hyper-V ของ Microsoft ก็สามารถนำมา Deploy ใน Nova ได้เช่นกัน

หลังจากนั้น OpenStack ก็ได้ขยาย Project โดยการเพิ่มโปรเจ็กต์ใหม่ๆ เข้าไปภายใต้สิ่งที่รู้จักกันในชื่อ OpenStack Integrated Release สำหรับ OpenStack Kilo ที่ปล่อยออกมาไม่นานนี้ มีการผสานรวมหลายๆ โปรเจ็กต์เข้าด้วยกัน ซึ่งได้แก่ Nova compute, Swift object storage, Cinder block storage, Keystone identity, Horizon dashboard, Glance image, Neutron networking, Trove database, Sahara Big Data, Heat orchestration, Ceilometer monitoring และ Ironic Bare Metal projects

ความท้าทายของ Integrated Release ก็คือ ในการใช้งาน OpenStack Cloud เราไม่ได้ใช้สิ่งที่อยู่ใน Integrated Release ครบทั้งหมด เริ่มด้วย Liberty Release ที่จะทำให้เกิดนิยามใหม่ขึ้นสำหรับ OpenStack แล้วไหนจะ DefCore Project ส่วนสำคัญที่ต้องเข้าไปอยู่ใน Cloud เพื่อให้สามารถเรียกได้ว่าเป็น OpenStack Cloud นอกจากนี้ยังมี Big Tent ซึ่งเต็มไปด้วยสารพัดโปรเจ็กต์ให้ผู้ใช้หรือผู้ให้บริการ Cloud ได้เลือกสรร

ทั้งนี้ Big Tent ได้เปลี่ยนคำนิยามของ OpenStack Cloud ไปเสียหมด ทั้งเรื่องที่ OpenStack Cloud คืออะไร และสามารถทำอะไรได้บ้าง นั่นหมายความว่า Liberty ที่ปล่อยออกมาก็จะสร้างความแตกต่างมหาศาลให้กับ OpenStack เช่นเดียวกัน อย่างไรก็ตาม DefCore ยังคงเป็นส่วนที่ขาดไม่ได้ ทั้ง Keystone Identity service และ API เพราะ Keystone คือตัวเปิดการทำงานของ Federated Identity หรือ การพิสูจน์ตัวตนแบบรวมศูนย์ ใน OpenStack Cloud ด้วยไอเดียที่จะให้ OpenStack Foundation กลายมาเป็น OpenStack Powered Planet คือ ให้เกิดศูนย์กลางการใช้งาน OpenStack ทั่วโลกนั่นเอง

 

Cloud Computing

Cloud Computing เป็นบริการ หน่วยจัดเก็บข้อมูล และระบบออนไลน์ต่างๆ แบ่งออกเป็น 3 ประเภท ได้แก่ Private, Public, และ Hybrid ถ้าอยากรู้ว่าแบบไหนที่น่าใช้ อันดับแรกต้องดูที่ระดับของความปลอดภัย และฟังก์ชั่นที่ตรงตามความต้องการ ประกอบด้วยลักษณะของ Data ที่จะนำไปใช้ร่วมกับ Cloud นั่นเอง

Public Clouds

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

Public Cloud จะเป็นตัวเลือกที่ดีที่สุดเมื่อ:

  1. Workload มาตรฐานสำหรับ Application ถูกใช้โดยคนจำนวนมาก เช่น E-mail
  2. ต้องการทดสอบและพัฒนา Application Code
  3. มี SaaS (Software as a Service) จากผู้ให้บริการที่เตรียมระบบรักษาความปลอดภัยและแผนการรับมือมาเป็นอย่างดี
  4. ต้องการความสามารถเพื่อรองรับ Workload ที่เพิ่มขึ้นอย่างมากในช่วง Peak Time
  5. มีโครงการหรืองานที่ต้องทำร่วมกับผู้อื่น
  6. ต้องการทำ ad-hoc software development project โดยใช้ PaaS (Platform as a Service) ผ่านทางระบบ Cloud

ข้อควรจำ: ผู้ดำรงตำแหน่งสูงในฝ่าย IT หลายคนกังวลเรื่องความปลอดภัยและความน่าเชื่อถือของ Public Cloud จึงต้องใช้เวลาพิจารณาศึกษาให้มั่นใจก่อนว่าระบบถูกออกแบบมาดี เพื่อป้องกันหรือรับมือได้เมื่อเกิดปัญหา นอกจากนี้การประหยัดงบประมาณในระยะสั้นอาจจะส่งผลเสียในระยะยาวได้

Private Clouds

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

Private Cloud จะเป็นตัวเลือกที่ดีที่สุดเมื่อ:

  1. มีการทำงานเกี่ยวกับ Data และ Application สำคัญ ซึ่งจะต้องมีความปลอดภัยและการควบคุมการเข้าถึงมาเป็นอันดับแรก
  2. มีการทำธุรกิจที่ใส่ใจเรื่องความปลอดภัยและความเป็นส่วนตัวของข้อมูลเป็นพิเศษ
  3. บริษัทหรือองค์กรมีขนาดใหญ่มากพอที่จะรัน Cloud Data Center อย่างมีประสิทธิภาพได้ด้วยตัวเอง

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

Hybrid Clouds

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

Hybrid Cloud จะเป็นตัวเลือกที่ดีที่สุดเมื่อ:

  1. ต้องการใช้ Application แบบ SaaS แต่ต้องการเรื่องความปลอดภัย ดังนั้นผู้ให้บริการ SaaS จึงสร้าง Private Cloud ขึ้นมาภายใต้ Firewall ของทางผู้ให้บริการ โดยผู้ใช้งานจะได้รับ VPN (Virtual Private Network) มาเป็นตัวเสริมความปลอดภัย
  2. เป็นธุรกิจที่ให้บริการในระบบตลาดแบบแนวตั้ง (Vertical Market) ซึ่งประกอบด้วยลูกค้าหลากหลายและเป็นอิสระแยกจากกัน จึงใช้ Public Cloud เพื่อติดต่อกับลูกค้า แต่เก็บข้อมูลของลูกค้าแต่ละรายไว้อย่างปลอดภัยภายใน Private Cloud

ข้อควรจำ: ระบบการจัดการ Cloud Computing จะมีความซับซ้อนสูงขึ้นมาทันที เมื่อต้องจัดการทั้ง Public Cloud, Private Cloud, และ Data Center ภายในไปพร้อมๆ กัน ดังนั้นในการจัดการ Hybrid Cloud จึงจำเป็นต้องมีการเพิ่มความสามารถสำหรับจัดการและจัดกลุ่มการทำงานร่วมของสภาพแวดล้อมที่ต่างกันพวกนี้

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

5 ขั้นตอนง่ายๆ กับการส่ง Application เข้า Container

ทุกวันนี้ Container กำลังมาแรง และได้รับการตอบรับดีขึ้นเรื่อยๆ ในตลาดของ Cloud ซึ่งประกอบด้วย Docker เป็นตัวนำ ก็ถือได้ว่ามีคนใช้งานเป็นจำนวนไม่น้อย เป็นอันดับต้นๆเลยก็ว่าได้ ซึ่งเราก็มีขั้นตอนในการติดตั้ง Application ลง Container 5 ขั้นตอนมาฝาก

สำหรับผู้ที่จะทดลองใช้ Docker เพื่อให้รู้แนวทางการใช้งานคร่าวๆ ดังนี้

  1. แยกส่วน (Decompose)

โดยปกติ Application มักจะมีองค์ประกอบอยู่หลายส่วน โดยส่วนใหญ่ต้องพึ่งพาระบบ Database และ Middleware Service สำหรับ Data Storage, Retrieval และ Integration เพราะฉะนั้นต้องแตก Service เหล่านี้ออกมาใส่ไว้ใน Container แยกเอาไว้เป็นส่วนๆ ด้วยการ Design และ Deployment ซึ่งมีการกระจายตัวมากเท่าไหร่ ก็ยิ่งเพิ่มความสามารถในการ Scale ได้มากขึ้นเท่านั้น ซึ่งนั่นหมายถึงความซับซ้อนในการบริหารจัดการก็จะมากขึ้นเช่นกัน

  1. เลือก Base Image

เราไม่ควรสร้างอะไรขึ้นมาในขณะที่ย้าย (Migrate) Application ควรจะหา Basic Docker Image จาก Docker Registry มาใช้เป็นพื้นฐานของ Application แทน โดยเมื่อเวลาผ่านไป หลายๆ องค์กรจะเริ่มเห็นค่าของ Docker Registry base Image ที่เพิ่มมากขึ้นเอง

  1. จัดการ Security และ Governance ให้เรียบร้อย

ความสำคัญของระบบ Security และ Governance ควรจะมาเป็นอันดับหนึ่ง ดังนั้นเราจึงไม่ควรที่จะละเลย และใส่เพิ่มลงใน Container ภายหลัง ซึ่งองค์กรจะต้องวางแผนระบบ Security และ Governance มาตั้งแต่แรก โดยออกแบบมันเข้าไปใน Application และจัดการให้เรียบร้อยในระหว่างอยู่ในขั้นตอน Operation เพื่อเป็นการรักษาความปลอดภัยให้มีประสิทธิภาพมากที่สุด

  1. เพิ่ม Code

ในการสร้าง Image องค์กรต้องมีการใช้ Dockerfile ซึ่งนับว่าเป็นขั้นตอนจำเป็นของงานนี้ และเมื่อสร้างเสร็จแล้ว จึงสามารถเพิ่มเข้าไป Docker Hub ได้

  1. Configure, Test, Deploy

จะต้องมีการตั้งค่า (Configure) ตัว Application ที่รันอยู่ภายใน Container เพื่อให้เชื่อมต่อกับ Resource ภายนอก และ Container ตัวอื่นภายใน Application Cluster นั้นได้ โดยสามารถติดตั้งการตั้งค่าเหล่านี้ลงไปใน Container เลย หรือจะใช้ Environment Variable ก็ได้

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

Hybrid Cloud ส่วนผสมที่ลงตัวของ Cloud Computing

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

วิธีการใช้งาน Hybrid Cloud ก็มีอยู่หลากหลาย เช่น

– แบ่งผู้ให้บริการเป็นทั้งแบบ Public Cloud และ Private Cloud โดยให้ใช้งานทั้ง 2 แบบ Integrated Service

ผู้ให้บริการ Cloud มี Hybrid Package ให้บริการเต็มรูปแบบ

– สำหรับองค์กรที่ใช้บริการ Private Cloud อยู่ก่อนแล้ว ก็ให้เข้าใจบริการ Public Cloud ก่อนจะประสานการทำงานเข้ากับ Infrastructure ของตน

สำหรับฟีเจอร์เด่นๆ ของ Hybrid Package ก็มีอยู่หลายอย่างด้วยกัน ตัวอย่างเช่น

– Scalability

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

– คุ้มราคาค่าใช้จ่าย

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

– ความปลอดภัย

Private Cloud ในระบบของ Hybrid Cloud มีระบบรักษาความปลอดภัยสำหรับการส่งและจัดเก็บข้อมูล ซึ่งนับว่าปลอดภัยในทุกๆ ขั้นตอน

– ความยืดหยุ่น

องกรณ์สามารถเลือกปรับแต่งทั้งระบบข้อมูล และราคาค่าบริการทรัพยากรสาธารณะ ที่มีความปลอดภัยได้ตามที่ต้องการ ทำให้เกิดความคุ้มค่าและเหมาะสมกับองค์กรมากที่สุด

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

Cloud bursting คืออะไร?

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

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

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

 

ปฏิวัติฝ่าย IT รองรับ Cloud อย่างจริงจัง!

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

ระบบ Cloud  เปิดโอกาสให้ IT Operation team สามารถเริ่มต้น IT Project ได้เอง ด้วยบริการ SaaS และ Service เสริมต่างๆ อย่างไรก็ดีการเปลี่ยนแปลงนี้มาพร้อมกับความเสี่ยงด้าน Security และ Workflow แต่สิ่งที่องค์กรควรทำคือลองเปลี่ยนไปใช้ Cloud Application ใหม่ๆ แยกส่วน Process ของ Application review ออกจากฝ่าย Application justification ทางด้าน Compliance และ Security Review ก็ควรประกอบด้วย Policy document ซึ่งระบุ Requirement ของ Application ที่จะใช้งาน และ Review Process โดยทีม IT จะต้องหมั่นสำรวจทรัพยากรของ Cloud application และตัดสินใจว่าต้องการใช้ทรัพยากรอะไรบ้างเพื่อให้สามารถทำงานได้ในระดับมาตรฐาน

นอกจากนี้ Cloud ยังเปลี่ยนรูปแบบการทำงานของฝ่าย IT อีกด้วย เพราะทรัพยากรของ คลาวด์ สามารถเช่าใช้งานได้ตามต้องการ ทำให้การวางแผนของทีม IT เปลี่ยนไปจากเดิม ไม่ต้องขึ้นอยู่กับทรัพยากรส่วนกลางของระบบ, Tools, และ Staff ภายในองค์กรเหมือนแต่ก่อน ระบบ Cloud ทำให้ฝ่าย IT สามารถจัดการกับความต้องการใช้งานทรัพยากรระยะสั้นได้ในราคาประหยัด ทั้งนี้ IT Operation team ก็ควรเช็คค่าใช้จ่ายว่ามูลค่าของ Data Center สูงกว่าการใช้ คลาวด์ จริงหรือไม่ โดยเฉพาะในส่วนของ PaaS กับ SaaS ที่น่าจับตามองเป็นพิเศษ เพราะช่วยประหยัดค่าบริการไปได้เยอะกว่า IaaS การตรวจสอบอย่างละเอียดและวางแผนให้รัดกุมมากพอ จะส่งผลดีต่อการจัดสรรทรัพยากรในระยะยาว นอกจากนี้ยังควรมีการเตรียม Technical support รองรับการทำงานอย่างต่อเนื่อง แล้วจึงกำหนดปริมาณทรัพยากร Data Center ให้สอดคล้องกับความพร้อมของ Cloud service ทั้งนี้ต้องไม่ลืมคำนวณค่าใช้จ่ายสำหรับส่วน Security และ Governance อีกด้วย

ปรับแต่ง Application deployment model เพื่อใช้กับ คลาวด์

เมื่อย้ายมาใช้ คลาวด์ แล้ว ฝ่าย IT ก็ต้องเตรียม Application Deployment Model ให้พร้อมรองรับการทำงานที่ครอบคลุม ซึ่งการที่แต่ละ Application มี Requirement แตกต่างกัน เพราะใช้ Resource ที่หลากหลาย ทำให้เกิดความยุ่งยากระหว่างการ Deploy ควรจะมีการสร้างนโยบายพื้นฐานเพื่อช่วยให้ฝ่าย IT และ User สามารถรับมือกับจำนวนทรัพยากรที่เพิ่มมากขึ้นได้ง่าย โดยโฟกัสไปที่ส่วนของโครงสร้างองค์กร, DevOps, Application Lifecycle Management (ALM) เป็นหลัก

การเปลี่ยนมาใช้ คลาวด์ อาจเสี่ยงต่อปัญหาการทำงานไม่ต่อเนื่องได้ เมื่อมีการย้ายมาใช้งานระบบใหม่ องค์กรอาจขาด IT support ทำให้ Workflow เกิดความไม่ต่อเนื่อง เพราะฉะนั้นการออกแบบ Cloud plan ให้สนับสนุนกับโครงสร้างองค์กรจึงเป็นเรื่องสำคัญมาก

กลยุทธ์ทาง DevOps สามารถช่วยเรื่อง Scale ของ Resource ที่กล่าวมาข้างต้นได้ โดย DevOps คือการใช้ Automate deployment tools เพื่อสร้างและรักษาเสถียรภาพ Application บน Host platform หากไม่ใช้ Tools นี้จะต้องไปพึ่ง Manual process ราคาแพง นอกจากนี้บาง Tools ของ DevOps ยังสามารถปรับแต่งให้ขยายขอบเขตการใช้งานไปยัง Cloud platform ได้อีกด้วย

ขั้นตอนสุดท้ายคือเรื่องของ ALM มีเป้าหมายเพื่อพัฒนา Application ด้วยการกำหนด Specific testing และ Deployment rules ผ่านทาง ALM Software แบบพิเศษ หลายๆ องค์กรจะรวม Security และ Governance เข้าไปในขั้นตอนของ ALM ด้วย ซึ่งนับว่าสำคัญมากต่อการวางแผนใช้งาน คลาวด์

Cloud Computing เบื้องต้น

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

 

Hybrid Cloud คืออะไร?

Hybrid Cloud คือ ระบบ Infrastructure ใดๆ ก็ตามที่มีการรวมเอาการทำงานของ Private Cloud และ Public Cloud เข้าไว้ด้วยกัน โดย Cloud ทั้ง 2 โมเดลจะร่วมกันจัดการด้าน Provisioning, Resource, และ Service ต่างๆ ให้เหมาะสมกับผู้เช่าใช้ที่สุด โดย Hybrid Cloud มีความ Flexibility และ Portability สูง สามารถทำงานได้กับหลายระบบปฏิบัติการ ที่สำคัญคือ Solution นี้เหมาะกับธุรกิจที่ต้องการรักษาความปลอดภัยของข้อมูล เนื่องจากมีการทำงานด้วยระบบ Encrypted Technology (เทคโนโลยีการเข้ารหัสข้อมูล)

Digital Transformation คืออะไร?

Digital Transformation คือ การเปลี่ยนแปลงไปสู่สิ่งที่ทันสมัยกว่า ด้วยวิธีการนำเทคโนโลยีใหม่ๆ มาปรับใช้ในองค์กรเพื่อตอบสนองความต้องการของลูกค้าให้ดีขึ้น ซึ่งแนวทางการทำงานขององค์กรจะเปลี่ยนไปตามรูปแบบของ Cloud, Social Network, Mobile Platform และ Big Data ที่นำมาใช้งาน โดยมีลักษณะเป็น Data-Driven มากกว่าเดิม หรือมีแรงผลักดันมาจากข้อมูลนั่นเอง

Cloud-Native Applications คืออะไร?

Cloud-native applications คือ โครงสร้าง Application สมัยใหม่ ที่มีมาตรฐานร่วมกัน โดดเด่นด้านความรวดเร็วในการทำงาน สามารถทำงานได้ในทุก Infrastructure ไม่ยึดติดกับ Cloud แบบใดแบบหนึ่ง และมีประสิทธิภาพการ Scalable สูง คือ สามารถทำการ Scale up และ Scale down ได้อย่างรวดเร็ว

Infrastructure as a Service (IaaS) คืออะไร?

IaaS คือ บริการที่ให้เราเข้าถึงระบบ IT Infrastructure รวมไปถึงพวก Resources ต่างๆ เช่น Storage, Network, และ Compute ที่เราต้องการใช้เพื่อรัน Workload ได้แบบ On-demand สามารถเข้าถึงและเลือกใช้ได้ตามใจชอบ โดยจ่ายค่าบริการราคาไม่แพง อิงตามปริมาณการใช้งานจริงเท่านั้น

Platform as a Service (PaaS) คืออะไร?

PaaS คือ Cloud-Based Environment ที่เราสามารถเช่าใช้งานเพื่อพัฒนา ทดสอบ รัน จัดการหรือปรับแต่ง Application เป็นการบริการสภาพแวดล้อมสำหรับ Development โดยที่เราไม่ต้องวุ่นวายเสียเวลาและเสียเงินไปกับการซื้อ สร้าง ดูแล และจัดการ Infrastructure ซึ่งนอกจากจะประหยัดแล้ว ยังช่วยให้ทำงานได้ง่ายและรวดเร็วขึ้น สามารถเปิดตัว Application ออกสู่ตลาดได้ทันใจ

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

 

Cloud Computing อีกหนึ่งรูปแบบบริการคลาวน์ที่คุณต้องรู้

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

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

หากองค์กรหรือธุรกิจใดต้องการที่ขยาย Server ก็สามารถทำได้ทันท่วงที จึงเหมาะมากกับการเติบโตของธุจกิจออนไลน์ปัจจุบัน และนั่นก็รวมไปถึงค่ายยักษ์ใหญ่อย่าง Amazon Web service เมื่อปีที่แล้วได้หันตัวมาเปิดตัวบริการคลาวน์ข้อมูลตลาดสำหรับนักวิจับและแพทย์ขึ้น และสิ่งนี้จะช่วยให้นักวิจัยต่างๆสามารวบรวมและวิเคราะห์ข้อมูลประชากร และการแสดงออกของยีนได้อย่างแม่นยำในเชิงและมันเป็นประโยชน์อย่างมากในเรื่องเกี่ยวกับหัวใจและหลอดเลือดในตอนแรกอาจจะเปิดให้ใช้บริการคลาวน์ตัวนี้ฟรี

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

ทำความรู้จักกับกระบวนการทำงานของ ระบบ Cloud

Cloud (คลาวด์) หลายคนคงเคยได้ยินผ่านหูมาบ้าง เพราะตอนนี้ ระบบ Cloud กำลังได้รับความนิยมเพิ่มมากขึ้นเรื่อยๆ แต่สำหรับใครที่ยังไม่รู้ แต่แค่เคยได้ยิน และอยากทำความเข้าใจว่าระบบ Cloud คืออะไร ทำงานอย่างไร วันนี้เราจะคุณไปรู้จักกับ Cloud (คลาวด์) กันนะคะ

มันคือเทคโนโลยีตัวหนึ่ง ขอยกตัวอย่างการทำงานของ Cloud (คลาวด์) ที่ใกล้ตัวก็คือ คุณใช้ iPhone แต่เมื่อคุณใช้ iPad ทุกอย่างบน iPhone คุณไปอยู่บน iPad Auto หรือแม้การเปลี่ยนโทรศัพท์เพียง Login iCloud ทุกอย่างก็กลับมาหมด อย่างนี้เป็นเรื่องใกล้ตัวของมนุษย์มากขึ้น

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

ส่วนตัวใช้ในแต่ละแผนกขององค์กรเข้ามาใช้งานได้ ในต่างประเทศนิยมใช้  Cloud (คลาวด์) เป็น Server มาก เพราะเวลาเราไม่ได้ไปทำงานในออฟฟิศ ก็สามารถซิงค์ข้อมูลกับอุปกรณ์และสามารถทำงานที่บ้านได้

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

เรียกได้ว่าเราสามารถแก้ปัญหาเองได้อย่างง่ายดาย  เห็นไหมละค่ะว่า Cloud (คลาวด์) คือเรื่องใกล้ตัวและมีอิทธิพลอย่างมากในการใช้ชีวิตในการทำงานของเรา

training.nipa.cloud เปิดคอร์ส เปิดหลักสูตร ฝึกอบรม Cloud OpenStack หลักสูตรและวิทยากรได้รับการรับรองจาก Mirantis หลักสูตรอบรมเป็นภาษาไทย งานสัมมนาด้านเทคโนโลยี Cloud