วันอาทิตย์ที่ 29 มิถุนายน พ.ศ. 2557

มาเล่น Phonegap Developer App กัน

Phonegap เพิ่งเปิดตัวโครงการ Phonegap Developer App ช่วยให้นักพัฒนาได้ทดสอบ Application ได้บน Mobile และ Tablet ได้โดยตรง โดยไม่ต้อง Build และติดตั้ง App ที่กำลังพัฒนาอยู่แต่อย่างใด เพียงแค่ติดตั้ง Phonegap Developer App แล้ว browse ไปที่ App ของคุณเท่านั้น :) วิธีการใช้งานก็ง่ายๆ



ติดตั้ง Phonegap Developer App ลงใน Mobile, Tablet ให้เรียบร้อยก่อน



หากยังไม่ได้ติดตั้ง Phonegap ก็ติดตั้งผ่าน npm ได้



sudo npm install -g phonegap



สร้างโปรเจคที่ต้องการ testapp



phonegap crate testapp



เปลี่ยน dir



cd testapp



จากนั้นก็สังให้ Phonegap ทำงานเป็น web server



phonegap serve



ตัว Phonegap จะแสดง ipaddress และ port ให้เรา จากนั้นเปิด Phonegap Developer App ขึ้นมา ต่อ Wifi ให้อยู่ในวงเดียวกับเครื่องคอมพิวเตอร์ของเรา จากนั้นใส่ url ที่ถูกต้อง เท่านี้ก็ทดสอบ Mobile App แบบไม่ต้องติดตั้งได้แล้ว :)









ผมว่าสะดวกดีครับ :)


วันจันทร์ที่ 23 มิถุนายน พ.ศ. 2557

ติดปัญหาเรื่องโอเพนซอร์สถาม Ask! TOSS

Thai Open Source เปิดบริการสอบถามปัญหาการใช้งานซอฟต์แวร์โอเพนซอร์สผ่านบริการใหม่ Ask! TOSS มีคำถามและคำตอบเกี่ยวกับการใช้งานซอฟต์แวร์โอเพนซอร์ส สามารถสอบถามปัญหาหรือค้นหาคำตอบของคำถามที่คุณสนใจได้ หากคุณคุณใช้ซอฟต์แว์โอเพนซอร์สแล้วติดปัญหาไม่รู้จะถามใคร ใช้บริการ Ask! TOSS ได้




วันศุกร์ที่ 20 มิถุนายน พ.ศ. 2557

มาเล่น GitLab CI กัน

ครั้งที่แล้วนำเสนอเรื่อง GitLab ไปมีพาดพิงเรื่อง CI (Continuous Integration) ไปนิดหน่อย ซึ่ง GitLab เองก็มีโครงการ GitLab CI เช่นกัน พูดถึง CI หลายท่านที่ใช้เครื่องมือแบบนี้อยู่แล้วก็คงต้องบอกว่า Jenkins เจ๋งสุด! แหมใช้ GitLab แล้วจะไปทำ CI ใน Jenkins ก็จะดูแปลกๆ มาใช้ GitLab CI กันดีกว่า :) GitLab CI แบ่งโครงการออกเป็น 2 ส่วน คือ




  • GitLab CI หน้าเว็บหลักของ GitLab CI

  • GitLab CI Runner เป็นส่วน Builder สามารถแยกหรืออยู่ร่วมกับ GitLab CI ได้



ครั้งนี้เราจะมาติดตั้ง GitLab + GitLab CI กัน โดยใช้วิธีที่ง่ายมากมากมาก โดยใช้ตัวติดตั้งของ Bitnami สำหรับวิธีปกติดูได้ที่เว็บโครงการ GitLab CI ครับ



ขั้นแรกดาวน์โหลด GitLab มาก่อน



wget http://downloads.bitnami.com/files/stacks/gitlab/6.9.2-1/bitnami-gitlab-6.9.2-1-linux-x64-installer.run



จากนั้น chmod ให้ execute ได้



chmod +x bitnami-gitlab-6.9.2-1-linux-x64-installer.run



ติดตั้งด้วยคำสั่ง



./bitnami-gitlab-6.9.2-1-linux-x64-installer.run



ตอบคำถามไปเรื่อยๆ คุณก็จะได้ GitLab และ GitLab CI มาใช้งานกันแล้ว วิธีการใช้งานก็เข้าไปที่ URL ของเว็บเราครับ ตัวอย่างเช่น



GitLab – http://redgitlabci.cloudapp.net
GitLab CI – http://redgitlabci.cloudapp.net/gitlabci



ตัวอย่างเป็น โครงการ OpenStack Cheat Sheet เขียนเป็นไฟล์ Markdown แล้วใช้ GitLab CI Build ออกมาเป็นไฟล์ EPUB ประมาณนี้



สร้าง Project ใน GitLab ขึ้นมาก่อนครับ





จากนั้นเข้าไปที่ GitLab CI สั่ง Sync Project เข้ามาและ Add เข้า Build





เข้าไปที่ Project > Settings เขียน Build Script เพิ่มลงไป เพราะเราจะใช้ make ช่วยในการ build ครับ





จากนั้น Commit ไฟล์เข้าไปที่ Git Repository





เข้าไปที่หน้าโครงการใน GitLab คุณจะพบ Badge แสดงสถานะ Build อยู่ตรงมุมขวา พอเรา Commit ไฟล์ CI ก็จะเริ่มทำงานตาม Build Script ที่เราเขียนเพิ่มลงไป







ดูสถานะและรายละเอียดการ Build เพิ่มได้ใน GitLab CI







GitLab CI จะ Build ให้เราทุกครั้งที่เรา Commit File เข้าไปที่ Repository คุณสามารถตั้งค่าการ Build เพิ่มเติมได้ในหน้า CI Settings ครับ


วันจันทร์ที่ 16 มิถุนายน พ.ศ. 2557

แนะนำแหล่งเรียน Git

มีคำถามกลับมาเกี่ยวกับ Git อีกเรื่องคือจะหาเรียน Git ได้ที่ไหน จะทำงานกับ Git ได้ยังไง ทำงานแบบ Collaboration ได้อย่างไร ใช้ Workflow แบบไหนดี หากคุณมีคำถามเหล่านี้ แนะนำให้ไปเรียนเลยครับ น่าเสียดายที่หลายสถาบันการศึกษาไม่ได้สอน Git แต่ใช่ว่าจะไม่มีแหล่งเรียน Git นะครับ แหล่งเรียน Git ที่ผมแนะนำมีดังนี้





ได้แหล่งเรียนเยอะเลย อย่ารอช้าลองเข้าไปศึกษาดูนะครับ


แนะนำ Git GUI

แนะนำ GitLab ไปเมื่อครั้งที่แล้ว ก็มีคำถามกลับมาเกี่ยวกับ Git หลายคำถามเลย ก็เลยขอทะยอยตอบผ่าน Blog ละกันครับ เรื่องแรกที่มักจะถามเข้ามากันบ่อยมากคือ ใช้ Git Command ไม่คล่อง มีโปรแกรมคลิ๊กง่ายๆ มั๊ย เอ่อ… ปกติผมก็ใช้ Git Command นะครับ ไม่เคยใช้ GUI สักที ในเว็บ Git SCM ในหน้าดาวน์โหลดแนะนำ Git GUI อยู่หลายตัว ลองเข้าเลือกดูได้ครับ สำหรับผมแนะนำ 2 ตัวนี้ครับ




  • GitHub GUI มีเวอร์ชั่นบน Windows, Mac

  • SourceTree มีเวอร์ชั่นบน Windows, Mac เช่นกัน



เครื่องมือ 2 ตัวนี้ฟรีครับ ยกเว้น SourceTree จะมีให้ลงทะเบียนนิดหน่อย แต่ไม่ยุ่งยาก ข้อดีของการใช้ GUI คงเป็นในเรื่องของการจัดการไฟล์ การ merge ไฟล์ และดู branch ครับ ถ้าชอบใช้ GUI ก็ลองติดตั้งใช้กันดูได้ :)





GitHub





SourceTree


มาเล่น GitLab กัน

ผมมักโดนถามคำถามเกี่ยวกับเครื่องมือที่ผมใช้งานอยู่บ่อยครั้ง ผมมักก็ตอบว่า Git, GitHub และตามด้วยประโยคที่ว่า “Private Project ต้องเสียเงิน ถ้าเป็น OpenSource Project ใช้ฟรี” ก็เลยมีหลายท่านถามว่า ​”เอาแบบ Private Project ไม่ต้องเสียเงินได้ไหม” งั้นแนะนำให้ใช้ GitLab เลยครับ เจ้า GitLab เหมาะสำหรับคนที่ใช้ GitHub มาก เพราะการใช้งานบนเว็บเหมือนกัน ไม่นับบน command line นะครับ :P นอกจากจะติดตั้งในหน่วยงานได้แล้วยังสามารถสร้าง Private Project ได้แบบไม่ต้องเสียเงินด้วย ตอบโจทย์เลยใช่มั๊ยครับ GitLab มีด้วยกัน 2 รุ่น คือ




  • GitLab Comminuty

  • GitLab Enterprise



ดูความแตกต่างของแต่ละรุ่นได้ที่หน้าเว็บ GitLab กันได้ นอกจากนี้ยังมี Jitlab CI ด้วย ซึ่งเราสามารถผูก GitLab กับ GitLab CI ได้ด้วย เอาไว้วันหลังจากมาเล่าให้ฟังว่าเล่นยังไง สำหรับวิธีการติดตั้ง GitLab นั้นมีหลายวิธี แต่ผมขอเลือกวิธีง่ายระดับมาก โดยใช้ GitLab Omnibus (มีวิธีแบบง่ายมากๆ อยู่ขอไม่กล่าวถึงละกันนะครับ) ลองมาติดตั้ง GitLab Community เล่นกันครับ



เริ่มจากดาวน์โหลด GitLab Omnibus กันก่อน



wget https://downloads-packages.s3.amazonaws.com/ubuntu-12.04/gitlab_6.9.2-omnibus.1-1_amd64.deb



ติดตั้ง package ที่ต้องใช้งาน



sudo apt-get install openssh-server postfix



ติดตั้ง gitlab



sudo dpkg -i gitlab_6.9.2-omnibus.1-1_amd64.deb



สร้าง file config



sudo mkdir -p /etc/gitlab



sudo touch /etc/gitlab/gitlab.rb



sudo chmod 600 /etc/gitlab/gitlab.rb



แก้ไข /etc/gitlab/gitlab.rb เพิ่มส่วน external_url ระบุ url ของ server เราครับ



external_url "http://redgitlab.cloudapp.net"



สั่ง reconfig ตั้งค่า gitlab ตาม config ใหม่



sudo gitlab-ctl reconfigure



ดูการตั้งค่าเพิ่มเติมได้ที่หน้า configuration เปิดเบราเซอร์ไปที่ gitlab server ของคุณตัวอย่าง http://redgitlab.cloudapp.net ล็อกอินด้วย root รหัสผ่าน 5iveL!fe





หน้าล็อกอิน





หน้า Dashboard





ลองสร้าง project ตัว gitlab สร้าง git repository ให้เราเรียบร้อยพร้อม commit code





ลอง clone gitlab-omnibus มาจาก gitlab repo จากนั้น push ไปที่ gitlab server ของเรา





ข้อมูลครบถ้วน





แสดงผล markdown ได้สวยงาม





รายการ commit





Network Branch ของ Project





สถิติการ commit, add, delete ของ project มีข้อมูลรายบุคคลด้วย


วันจันทร์ที่ 9 มิถุนายน พ.ศ. 2557

มาเล่น OPEN edX กัน

edX เป็นคอร์สเรียนออนไลน์จากมหาวิทยาลัยชั้นนำต่างๆ ที่เปิดโอกาสให้ผู้เรียนนอกจากคอร์สปกติได้มีโอกาสเรียนผ่านระบบอินเตอร์เน็ต ซึ่งปัจจุบันมีมหาวิทยาลัยชั้นนำอย่าง MIT, Stanford, Harvard หรือแม้กระทั่ง Linux Foundation ก็เปิดหลักสูตร Intro to Linux บน edX เช่นกัน นอกจากการให้บริการคอร์สเรียนออนไลน์แล้ว edX ยังเปิดโค้ดของระบบหลังบ้านทั้งหมดเป็นโอเพนซอร์สโดยใช้สัญญาอนุญาติแบบ AGPL ภายใต้โครงการ OPEN edX โครงการนี้มีมหาวิทยาลัยหลายแห่งร่วมกันพัฒนานา เช่น Stanford University, MIT, The University of Queensland, Tsinghua University, UC Berkeley Harvard University และ Google ทำให้โครงการ OPEN edX มีการพัฒนาอย่างต่อเนื่อง



สำหรับผู้ที่สนใจ OPEN edX สามารถทดลองใช้งานกันได้ผ่าน





หรือติดตั้งแบบ





อันนี้แล้วแต่เลือกครับ ใครมี AWS ก็ใช้ Cloud Formation Template ช่วยได้ แต่คนที่ไม่ทีแล้วอยากติดตั้งเล่นเอง ไม่อยากเล่นผ่าน vagrant ก็สามารถติดตั้งเองได้ครับ



เตรียมเครื่องเซิร์ฟเวอร์ที่มีคุณสมบัติดังนี้




  • CPU 4 Cores ขึ้นไป

  • Memory 4GB ขึ้นไป

  • HDD 50GB ขึ้นไป

  • เชื่อมต่อ internet

  • ติดตั้ง Ubuntu 12.04.4 LTS 64 Bits Server



ผมไม่มีเครื่องเซิร์ฟเวอร์แบบนี้ ก็เลยอาศัยบริการของ Microsoft Azure โดยใช้เครื่องแบบ Standard ขนาด A4 ครับ สำหรับท่านที่เงินไม่พอก็ใช้ขนาด Standard A3 ก็ได้ครับ :) มาลงมือกันเลย



เริ่มจากอัพเดท package และอัพเกรดระบบกันก่อน



sudo apt-get update -y



sudo apt-get upgrade -y



sudo reboot



จากนั้นติดตั้ง package ที่ต้องใช้งานกัน อ้อเกือบลืมไป เราจะใช้ ansible เป็นระบบ configuration นะครับ ที่ต้องใช้ ansible เพราะ OPEN edX บังคับใช้ครับ T_T



sudo apt-get install -y build-essential software-properties-common python-software-properties curl git-core libxml2-dev libxslt1-dev python-pip python-apt python-dev



อัพเดท pip และ virtualenv ก่อน



sudo pip install --upgrade pip



sudo pip install --upgrade virtualenv



จากนั้น clone configuration script (playbook) จาก github มา



cd /var/tmp



git clone -b release https://github.com/edx/configuration



ติดตั้ง dependency package ที่ต้องใช้เพิ่มเติม



cd /var/tmp/configuration



sudo pip install -r requirements.txt



จากนั้นเข้าไปที่ playbooks ที่เราต้องใช้ แล้วสั่งติดตั้งได้เลย



cd /var/tmp/configuration/playbooks



sudo ansible-playbook -c local ./edx_sandbox.yml -i "localhost,"



นั่งรอประมาณ 2 ชั่วโมงครับ ถ้าไม่มี error แดงๆ แล้วหลุดมาที่ shell เป็นอันใช้ได้ ที่บอกอย่างนี้เพราะ playbook script ทำออกมาได้เห่ยมากครับ :P



เอาล่ะ ระหว่างนี้เกิดอะไรขึ้นบ้าง playbook จะติดตั้ง OPEN edX Platform ลงไปที่ /edx ติดตั้ง python modules, ruby, supervisord, mongodb, openjdk และอื่นๆ เรื่องที่ต้องทราบก่อนจะเข้าไปเล่นในระบบ



ansible แก้ไขไฟล์ระบบบางส่วนด้วย ตาม rules ใน playbooks ระหว่างนี้ห้ามออกจาก ssh เพราะว่า ansible แก้ไข sshd_config ด้วย เพื่อจัดการเรื่อง security ซึ่งมีผลทำให้คุณจะต้องใช้ ssh key ในการ remote เข้ามา ให้ติดตั้ง public key ให้เรียบร้อย ก่อน log out ไม่ใช่นั้นคุณจะ ssh เข้าระบบไม่ได้ ;)



ระบบติดตั้ง sample user มา 4 คน คือ




  • audit@example.com รหัสผ่าน edx

  • honor@example.com รหัสผ่าน edx

  • staff@example.com รหัสผ่าน edx

  • verified@example.com รหัสผ่าน edx



แต่ไม่มี admin ของระบบ อันนี้คงเป็นเรื่องความปลอดภัยเช่นกัน (เดานะ) การเปลี่ยน role ต้องทำผ่าน edX command line เท่านั้น หรือผ่านหน้า admin ของ Djungo วิธีการสร้าง superuser ดูได้ที่หน้า Wiki ครับ



OPEN edX Platform จะมีระบบ 2 ส่วนใหญ่ๆ คือ




  • LMS - http://your-edx-server.com

  • Studio - http://your-edx-server.com:18010



LMS คือส่วนของห้องเรียน และ Studio คือเครื่องมือสร้างบทเรียน เวลาเข้าใช้งานก็เข้าให้ถูก port นะครับ มาดูหน้าจอกันว่ามีอะไรบ้าง