CategoryDo

Quản lý dự án là gì?

Dự án (Project) là gì?

Trước khi nói đến “Quản lý dự án”, tôi nghĩ rằng chúng ta nên cùng nhau định nghĩa lại “Dự án” là gì?.

Khi nhắc đến từ khoá “Dự án”, hầu hết mọi người sẽ nghĩ đến một cái gì đó rất chuyên nghiệp, ví dụ như: quy trình, giám đốc, công ty, tập đoàn, ..; tuy nhiên trên thực tế, “Dự án” đơn giản chỉ là một hoạt động hoặc một chuỗi những hoạt động được xác định điểm bắt đầu, điểm kết thúc một cách rõ ràng, để đạt được một mục tiêu nào đó, với một nguồn lực giới hạn.

Mỗi một dự án được lập ra để đạt một mục tiêu riêng, thường là “nắm bắt cơ hội” hoặc “giải quyết vấn đề” nào đó. Chính vì như vậy, hoạt động của dự án chỉ diễn ra một lầnkhông có tính lặp lại.

Các dự án xuất hiện ở khắp mọi nơi trong cuộc sống thường ngày của chúng ta mà chúng ta không để ý đến. Ví dụ như: Tổ chức đám cưới, xây nhà, mở một cửa hàng online, học một kỹ năng mới, tổ chức một chuyến du lịch, ..; Tất cả những hoạt động kể trên đều có thể coi là những dự án.

Quản lý dự án (Project Management) là gì?

Mỗi một dự án đều có mục tiêu riêng, vậy “Quản lý dự án” đơn giản chỉ là việc sử dụng những hiểu biết, kỹ năng, công cụ, kỹ thuật để đạt được mục tiêu của dự án.

Ví dụ bạn dự định mở một cửa hàng online, thế thì những việc bạn cần làm sẽ là: Xác định khách hàng, nhu cầu của khách hàng, sản phẩm sẽ bán, nguồn nhập hàng, các kênh bán hàng, số vốn cần có, các nhân sự tham gia, …; Mọi hoạt động động kể trên đều có thể liệt vào các đầu việc thuộc phạm vi quản lý dự án.

Để làm rõ hơn thì chúng ta có thể trả lời những câu hỏi sau:

Câu hỏi 1: Vấn đề chúng ta đang giải quyết là gì? (Hoặc cơ hội chúng ta đang nắm bắt là gì?)

Câu hỏi này sẽ giúp chúng ta xác định được mục tiêu của dự án, lí do vì sao mà dự án đó được ra đời.

Câu hỏi 2: Chúng ta sẽ giải quyết vấn đề đó bằng cách nào?

Bằng cách trả lời câu hỏi này, chúng ta sẽ xác định được các “Giải pháp” và cách thức để giải quyết được vấn đề. Xác định được những việc chúng ta cần làm, những gì chúng ta cần tạo ra, nguồn lực chúng ta cần để đạt được mục tiêu của dự án.

Câu hỏi 3: Kế hoạch của chúng ta là gì?

Sau khi đã xác định được Mục tiêu và Giải pháp thì bước tiếp theo chúng ta cần có kế hoạch chi tiết từng bước để thực hiện chúng. Chúng ta sẽ lên danh sách những việc cần làm, nguồn lực cần có, các lịch trình, các quy trình liên quan, …

Câu hỏi 4: Làm thế nào để chúng ta biết chúng ta đã hoàn thành dự án?

Có rất nhiều dự án không có hồi kết, chỉ vì ngay từ đầu nó không được xác định một điểm đến rõ ràng. Chúng ta cần xác định trước đích đến và cách thức để kiểm tra xem chúng ta đã đến đích hay chưa.

Phạm vi thành công (Success Criteria) sẽ giúp chúng ta đánh giá kết quả của dự án, với điều kiện nó phải “đo đếm được”.

Câu hỏi 5: Dự án đã diễn ra như thế nào?

Sau khi dự án kết thúc, phần lớn chúng ta sẽ quên mất một việc quan trọng, đó là: Đánh giá lại dự án. Chúng ta có thể rút được rất nhiều những kinh nghiệm thông qua việc trả lời những câu hỏi như: Điều gì chúng ta đã làm tốt? Điều gì chưa tốt? Tại sao? Điều gì chúng ta có thể cải tiến trong dự án tiếp theo?

Vậy tổng kết lại, chúng ta có thể nói việc Quản lý dự án về bản chất chính là việc sử dụng những hiểu biết, kỹ năng, công cụ và kỹ thuật một cách khoa học để trả lời những câu hỏi phía trên, từ đó đạt được mục tiêu của dự án.

SSH là gì? Hướng dẫn kết nối đến máy chủ Linux thông qua SSH

SSH là gì?


SSH (Secure Shell) là một giao thức mạng, giao thức này cho phép chúng ta kết nối đến một máy chủ Linux từ xa thông qua mạng Internet. Mọi dữ liệu gửi và nhận thông qua SSH đều được mã hóa giúp bảo mật thông tin an toàn hơn.
Ví dụ bạn thuê một máy chủ Linux (máy chủ này có thể là vật lý, có thể là máy ảo) để chạy website, trên thực tế máy chủ này được đặt ở một DC nào đó, để có thể toàn quyền cài đặt và điều khiển máy chủ đó bạn cần kết nối với máy chủ đó từ xa. SSH cho phép bạn làm điều đó.

Cài đặt SSH trên máy chủ

Để có thể kết nối được từ một máy tính khác đến máy chủ thông qua giao thức SSH thì máy chủ của bạn phải được cài sẵn SSH.
Nếu bạn thuê máy chủ thì thường bước này nhà cung cấp đã làm hộ bạn và sẽ cung cấp cho bạn tài khoản để kết nối luôn.
Nếu bạn tự cài máy chủ thì tham khảo các câu lệnh sau:

Với RHEL/CentOS

yum -y install openssh-server openssh-clients
chkconfig sshd on
service sshd start

Với Ubuntu/Debian

sudo apt install openssh-client
sudo apt install openssh-server

Sau khi cài đặt xong bạn có thể cấu hình SSH thông qua file config: /etc/ssh/sshd_config .
(Cụ thể cách cài đặt và cấu hình SSH trên máy chủ Linux mình sẽ chia sẻ ở một bài viết khác nhé các bạn.)

Đăng nhập vào máy chủ thông qua SSH

Để có thể đăng nhập vào máy chủ thông qua SSH, ta cần có những thông tin sau:

  • IP máy chủ, ví dụ: 10.10.8.10.
  • Tên đăng nhập người dùng (username), thường là root.
  • Mật khẩu người dùng (password).
  • Cổng giao tiếp, mặc định SSH sử dụng cổng 22.

Những thông tin này nếu bạn đi thuê máy chủ bạn sẽ được cung cấp sau khi bạn ký hợp đồng dịch vụ.

Đăng nhập từ một Linux hoặc MacOS

Nếu bạn kết nối từ một máy hệ điều hành Linux hoặc MacOS thì bạn đã được hỗ trợ sẵn SSH, vì vậy bạn chỉ cần mở Terminal và gõ câu lệnh với cú pháp sau:

ssh <username>@<IP>

Ví dụ:

ssh [email protected]

Sau đó nhập hoặc past mật khẩu và ấn Enter. Done.
Mặc định port kết nối là 22, trong trường hợp không sử dụng port mặc định thì chúng ta thêm tham số -p, ví dụ:

ssh [email protected] -p 1234

Đăng nhập từ một Windows

Nếu bạn kết nối từ một máy chạy hệ điều hành Windows thì bạn cần sử dụng một ứng dụng hỗ trợ. Ứng dụng thông dụng nhất mình biết là PuTTY. Bạn có thể truy cập putty.org  để tải ứng dụng. Cách sử dụng cũng khá đơn giản, bạn chỉ cần nhập đầy đủ thông tin và kết nối.
(Các bạn thông cảm vì mình không sử dụng Windows nên không thể hướng dẫn các bạn chi tiết được.)
Ngoài ra với giao thức SSH chúng ta có một cách khác để kết nối với máy chủ mà không cần đăng nhập, cách này thường được sử dụng để cài đặt các tác vụ tự động hóa giữa các máy chủ với nhau. Mình sẻ chia sẻ với các bạn trong một bài viết khác nhé.
 

Cron format – Định dạng và cú pháp Cron trên Linux

Trong bài viết này mình sẽ chỉ nói về định dạng và cú pháp của Cron, việc cài đặt Cron Job mình sẽ chia sẻ trong một vài viết khác.
Nói qua một chút về Cron Format. Cron Format là một định dạng thời gian để xác định tần xuất của một tác vụ nào đó của hệ thống , định dạng này được thiết kế với tiêu chí đơn giản, hiệu quả, linh hoạt. Ví dụ các tác vụ như: Backup Database, Polling SCM…
Cron Format bao gồm có 5 trường giá trị riêng biệt được phân cách nhau bởi dấu “TAB” hoặc dấu cách “Whitespace”.

<Phút> <Giờ> <Ngày_trong_tháng> <Tháng_trong_năm> <Ngày_trong_tuần>

Nếu sử dụng nnCron thì chúng ta có thể có thêm trường thứ 6 là <Năm> .
Các giá trị khả dụng:

  • Phút: 0-59
  • Giờ: 0-23
  • Ngày trong tháng: 1-31
  • Tháng trong năm: 1-12
  • Ngày trong tuần: 0-6 hoặc 1-7. Lưu ý: Chủ nhật được coi là ngày đầu tiên.
  • Năm: 1900-3000

Các cú pháp đặc biệt:

  • * : Tất cả những giá trị khả dụng.
  • M-N : 1 khoảng giá trị. Ví dụ: 5-8 .
  • A,K,Z : tập hợp các giá trị. Ví dụ: 1,5,6,8,30 .

Hãy xem xét các ví dụ sau để hiểu rõ hơn:
* * * * * : Mỗi phút.
0 0 * * * : Vào 0 giờ 0 phút mỗi ngày.
0 2-4 * * * : Vào 2 giờ, 3 giờ và 4 giờ mỗi ngày.
* * * 2,4,6,8,10,12 * * : Mỗi phút trong tháng 2, 4, 6, 8, 10, 12.
0 0 1 * * * : 0 giờ 0 phút vào các ngày đầu tiên của tháng.
Ngoài ra các bạn có thể tham khảo 1 số tool có thể giúp mình làm việc dễ dàng hơn với Cron như: crontab-generator.org , crontab.guru ..
Mình sẽ chia sẻ cách cài đặt và cấu hình Cron trên hệ thống trong một bài viết khác nhé!

CI Jenkins – Cài đặt Jenkins trên máy ảo Laravel Homestead

Bài viết này hướng dẫn các bạn cài đặt Jenkins trên máy ảo Laravel Homestead. Việc cấu hình và sử dụng Jenkins mình sẽ chia sẻ trong một bài viết khác.
Ngoài ra nếu bạn chưa biết cài đặt Laravel Homestead, hãy tham khảo bài viết này: Laravel Homestead – Môi trường phát triển chuẩn cho Laravel.
Các bước hướng dẫn dưới đây là các bước sau khi các bạn chạy câu lệnh vagrant ssh  để kết nối với máy ảo.

Bước 1: Cài đặt Java

Các bạn tham khảo bài viết này nhé: Hướng dẫn cài đặt Java JDK trên Ubuntu.

Bước 2: Cài đặt Jenkins

Thêm repository key vào hệ thống: wget -q -O – https://pkg.jenkins.io/debian-stable/jenkins.io.key | sudo apt-key add – .
Mở file sources.list  với câu lệnh sudo vi /etc/apt/sources.list , thêm vào cuối file deb https://pkg.jenkins.io/debian-stable binary/ .
Cập nhật package: sudo apt-get update .
Cài đặt Jenkins: sudo apt-get install jenkins .
Mặc định sau khi cài đặt Jenkins sẽ tự động chạy tại cổng 8080 , chúng ta có thể truy cập vào Jenkins thông qua trình duyệt với đường dẫn: http://ip_may_chu_cua_ban:8080 . Ví dụ: http://10.10.8.10:8080 .

Bước 3: Unlock Jenkins

Sau khi truy cập vào Jenkins thành công qua trình duyệt, chúng ta sẽ nhận được bảng thông báo như sau:

Để đảm bảo bảo mật thì Jenkins bắt buộc chúng ta phải lấy mã Admin trong file initialAdminPassword trên máy chủ.
Chạy lệnh sau để lấy mã: sudo cat /var/lib/jenkins/secrets/initialAdminPassword .
Output sẽ có dạng: d177322e66ca4ba38034fbfeada344c0 .
Copy đoạn mã và past vào ô Administrator password sau đó ấn Continue.

Bước 4: Đổi mật khẩu Admin

Sau khi đã có quyền truy cập vào Jenkins, điều đầu tiên chúng ta cần làm là đổi mật khẩu Admin.
Ở góc trên bên phải sẽ có 1 nút Admin , ấn vào đó, tiếp tục ở cột bên trái sẽ có Configure , tiếp tục ấn vào form cập nhật thông tin sẽ hiện ra.
Sau khi đổi mật khẩu admin coi như chúng ta đã tạm cài đặt xong Jenkins lên máy chủ, các bước tiếp theo mình sẽ hướng dẫn trong một bài viết khác nhé!

Hướng dẫn cài đặt Java trên Ubuntu

Để kiểm tra xem máy chủ của bạn đã được cài Java chưa, gõ lệnh: java -version .
Nếu output tương tự thế này thì máy bạn đã cài Oracle Java rồi:

java version "1.8.0_131"
Java(TM) SE Runtime Environment (build 1.8.0_131-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.131-b11, mixed mode)

Hoặc nếu output tương tự thế này thì máy của bạn đã được cài Java Open JDK rồi:

openjdk version "1.8.0_151"
OpenJDK Runtime Environment (build 1.8.0_151-8u151-b12-0ubuntu0.16.04.2-b12)
OpenJDK 64-Bit Server VM (build 25.151-b12, mixed mode)

Nếu chưa, tham khảo các bước sau để cài đặt Java:

Bước 1: Cài đặt Java thông qua apt-get

Cài đặt Java Open JDK

sudo apt-get install default-jdk

Bạn có thể thay đổi phiên bản mong muốn, ví dụ:

sudo apt-get install openjdk-8-jdk
sudo apt-get install openjdk-7-jdk

Hoặc cài đặt Oracle Java

Mặc định Java không có sẵn trong repository của Ubuntu, vì vậy ta cần add thêm:

sudo add-apt-repository ppa:webupd8team/java

Cập nhật lại Apt package:

sudo apt-get update -y

Cài đặt Oracle Java:

sudo apt-get install oracle-java8-installer

Kiểm tra lại version của Java:

java -version

Bước 2: Cấu hình JAVA_HOME

Mở file enviroment với câu lệnh: sudo vi /etc/environment
Sau đó thêm vào cuối file dòng: JAVA_HOME=”/usr/lib/jvm/java-8-openjdk-amd64″ hoặc /usr/lib/jvm/java-8-oracle/  nếu cài đặt Oracle Java.
Lưu ý đường dẫn đến Java home có thể khác tùy thuộc vào phiên bản, vì vậy cách tốt nhất các bạn cd /usr/lib/jvm  sau đó ls -la  để xác định Java home phù hợp nhé.
Bước cuối cùng, chạy lệnh source /etc/environment để tải lại file enviroment.
Chúc các bạn thành công!.

Cài đặt Laravel Homestead – môi trường phát triển chuẩn cho Laravel – sử dụng Vagrant, Virtual Box

Hãy hình dung, bạn có một nhóm cùng với nhau phát triển một dự án, khi đó vấn đề nảy sinh là: Mỗi thành viên trong team sử dụng một hệ điều hành khác nhau, dẫn đến khả năng phát sinh lỗi khi phát triển là rất cao, nhiều khi dự án chạy trên máy người này thì ổn, nhưng sang máy của một thành viên khác thì lại lỗi, gây khó khăn cho cả nhóm, tốn thời gian sửa lỗi không cần thiết. Vấn đề này không chỉ nảy sinh với những nhóm phát triển Laravel mà nó cũng là vấn đề với bất kỳ nhóm phát triển nào.

Vậy thì, làm thế nào để giải quyết vấn đề này?

Ý tưởng: Tất cả các thành viên trong nhóm sẽ cài đặt một máy ảo trên máy của mình và làm việc trên đó, máy ảo này sẽ được cài đặt đầy đủ tương đương với môi trường khi deploy.
Vấn đề phát sinh tiếp theo là mỗi thành viên khi cài đặt máy ảo của mình thì chưa chắc đã cài đặt đủ, đúng phiên bản các công cụ, dịch vụ, và hơn nữa là cũng khá tốn thời gian để cài đặt từng cái.
Và một vấn đề nữa, nhiều bạn đọc đến đây chắc vẫn đang băn khoăn “Nếu cài máy ảo thì tôi lại phải code trên máy ảo à? tôi không thích như vậy! tôi thích làm việc trên hệ điều hành quen thuộc của tôi cơ!”.
Chúng ta có quá nhiều vấn đề nhỉ, nhưng không sao, Vagrant có thể giúp chúng ta xử lý hết những vấn đề ở trên.
Trước hết hãy tìm hiểu xem “Vagrant là gì?”

Vagrant là gì?

Vagrant là một sản phẩm của HashiCorp, nó là một công cụ giúp chúng ta xây dựng môi trường phát triển. Hiểu đơn giản thì vagrant sẽ là cầu nối giữa máy tính cá nhân của chúng ta và máy ảo. Chúng ta vẫn code trên máy chúng ta như bình thường, và vagrant sẽ tự động đồng bộ nó với máy ảo, và máy ảo sẽ làm nhiệm vụ biên dịch và thông dịch, và hơn nữa máy ảo này có thể share được cho mọi người trong nhóm. Cool 😀
Hiểu sơ sơ vậy đủ rồi, giờ bắt tay vào cài đặt thôi.

Cài đặt Virtual Box

Đầu tiên chúng ta sẽ cài Virtual Box, đây là phần mềm tạo và cài đặt máy ảo, trên máy ảo sẽ được cài đặt sẵn môi trường làm việc phù hợp.
Ví dụ máy ảo để lập trình Laravel (Web/PHP) sẽ bao gồm:

  • Ubuntu 14.04
  • Git
  • PHP 7.0
  • HHVM
  • Nginx
  • MySQL
  • MariaDB
  • Sqlite3
  • Postgres
  • Composer
  • Node (With PM2, Bower, Grunt, and Gulp)
  • Redis
  • Memcached
  • Beanstalkd

Chú ý, theo kinh nghiệm cá nhân mình, phiên bản ổn định nhất của Virtual Box hiện tại là phiên bản 4.0.10 hoặc 4.0.12.

Cài đặt Vagrant

Tiếp theo chúng ta sẽ cài Vagrant, như đã nói ở trên thì Vagrant sẽ là cầu nối giữa máy chúng ta đang làm việc và máy ảo, mọi cập nhật trên máy chúng ta sẽ được đồng bộ với máy ảo ngay lập tức.

Add Vagrant Box

Sau khi cài đặt xong Virtual Box và Vagrant, bước tiếp theo chúng ta sẽ add box trên Vagrant. Vagrant cung cấp khái niệm box, mỗi box tương đương với một máy ảo. Tuỳ vào ngôn ngữ chúng ta sử dụng và yêu cầu của từng team chúng ta sẽ chọn những box khác nhau, danh sách các box được chia sẻ và tổng hợp tại hashicorp.
Với Laravel thì chúng ta sẽ chọn laravel/homestead. Bạn có thể thấy nó ở ngay trang đầu trên hashicorp.
Mở Terminal và gõ vagrant box add tên_box, VD: vagrant box add laravel/homestead
Máy tính bạn sẽ tự động tải bộ cài máy ảo tương ứng, dung lượng khoảng 1GB nên thời gian chờ cũng khá lâu.

Trường hợp mạng yếu tải Vagrant Box xảy ra lỗi

Có một số trường hợp do mạng yếu mà không thể tải được, để ý một chút chúng ta có thể thấy bên trong thông báo lỗi có đường dẫn tải box, chúng ta có thể copy link đó và tải trên trình duyệt, tốc độ sẽ nhanh và ổn định. Sau khi tải xong chúng ta lại chạy câu lệnh add như ở trên nhưng thêm path đến file vừa tải vào cuối.
vagrant box add /Volumes/Data/Setup/Homestead/hc-download
Với trường hợp này, để tránh phát sinh thêm lỗi về sau khi vagrant up, chúng ta tạo một file metadata.json, chứa nội dung như sau:

{
    "name": "tên_box",
    "versions": [{
        "version": "0.4.0",
        "providers": [{
            "name": "virtualbox",
            "url": "đường_dẫn_đến_file_box_đã_tải "
        }]
    }]
}

Sau đó chạy câu lệnh: vagrant box add metadata.json
Mình khuyến khích các bạn dùng cách này, vì sau này khi muốn add lại box mình không mất công tải lại box, chỉ cần add lại file metadata.json  là xong.

Trường hợp box đã tồn tại

Sử dụng lệnh vagrant box list  để hiển thị các box đang có.
Dùng lệnh vagrant box remove tên_box  để xoá box.
Xoá Vagrantfile hiện tại rm Vagrantfile .
Tiếp đến quay lại bước vagrant box add .

Config Vagrant

Tiếp theo chúng ta phải config lại vagrant một chút. Trước khi làm việc đó thì chúng ta chạy một vài câu lệnh nhỏ sau đây để khởi tạo.

git clone https://github.com/laravel/homestead.git Homestead
cd Homestead
bash init.sh
ssh-keygen -t rsa -C "[email protected]"

Chú ý, nếu bạn cài đặt trên Window thì có thể vào thẳng folder Homestead và chạy file init.bat .
Sau đó chúng ta sẽ có 1 folder .homestead  và file ~/.homstead/Homestead.yaml
Mở file Homestead.yaml , chúng ta cần chỉnh sửa một chút cho phù hợp, chú ý đoạn sau:

ip: "10.10.8.10"
...
folders:
- map: /Users/Jeremy/Homestead
to: /home/vagrant/Code
sites:
- map: toanf.dev
to: /home/vagrant/Code/toanf.com/public

Nhìn qua chắc bạn cũng có thể hình dung ra, mọi thứ trong /Users/Jeremy/Homestead  trên máy thật sẽ được đồng bộ với /home/vagrant/Code  trên máy ảo.
10.10.8.10  chính là ip của máy ảo, bạn có thể đổi tuỳ ý, miễn là không bị trùng với local của bạn là được.
toanf.dev  bạn có thể hiểu đơn giản nó là domain mà bạn sẽ gõ trên trình duyệt, còn /home/vagrant/Code/toanf.com/  là nơi chứa code laravel. Tất nhiên bạn sẽ phải add 10.10.8.10 toanf.dev  vào file hosts  trên máy bạn thì nó mới có thể chạy được.
Sắp xong rồi, giờ chúng ta mở terminal trong folder ~/Homestead  và chạy câu lệnh: vagrant up  để khởi động máy ảo.
Chúng ta cũng có thể connect với máy ảo qua ssh bằng câu lệnh: vagrant ssh
Vậy là xong, giờ chúng ta đã có môi trường ngon lành để làm việc với đầy đủ các công cụ, dịch vụ cần thiết mà không cần mất công đi cài đặt từng cái một, config từng cái một.
Một số câu lệnh làm việc với Vagrant

vagrant up #Khởi động máy ảo
vagrant reload #Restart máy ảo
vagrant halt #Tắt máy ảo
vagrant ssh #Truy cập máy ảo qua ssh

Chú ý, sau này khi muốn tương tác với máy ảo chúng ta cần mở terminal trong folder ~/Homestead  hoặc gõ lệnh vagrant global-status  để liệt kê các máy ảo, tiếp theo gõ câu lệnh vagrant theo cú pháp vagrant [lệnh] [id_máy_ảo] , ví dụ: vagrant up 1f5321 .
Ở bài viết này, mình chỉ đề cập chi tiết cách cài với mục đích sử dụng để phát triển Laravel, ứng với yêu cầu của team mình thì các bạn có thể tự tìm hiểu thêm nhé.

Bổ sung cách khắc phục một số lỗi phát sinh.

Lỗi:

==> default: Booting VM...
==> default: Waiting for machine to boot. This may take a few minutes...
The guest machine entered an invalid state while waiting for it
to boot. Valid states are 'starting, running'. The machine is in the
'poweroff' state. Please verify everything is configured
properly and try again.
If the provider you're using has a GUI that comes with it,
it is often helpful to open that and watch the machine, since the
GUI often has more helpful error messages than Vagrant can retrieve.
For example, if you're using VirtualBox, run vagrant up while the
VirtualBox GUI is open.

Khắc phục: thêm đoạn config sau vào Vagrantfile

config.vm.provider "virtualbox" do |vb|
vb.customize ["modifyvm", :id, "--accelerate3d", "off"]
end

© 2020 AT Nguyen

Theme by ATUp ↑