Use Serverless Devs To Manage Function Computing Resources
1. Experiment
1.1 Knowledge points
In this experiment, Alibaba Cloud Function Compute is used. This experiment describes how to use Serverless Devs to manage Function Compute resources.
Serverless Devs is an open source platform for serverless application developers. Serverless Devs allows you to develop, create, test, and deploy an application and to manage the full lifecycle of the application.
1.2 Experiment process
- Install Serverless Devs
- Configure Serverless Devs
- Deploy the service
- Example: Building a frontend CICD
1.3 Scene architecture diagram
data:image/s3,"s3://crabby-images/3bea7/3bea76de7d56ec350688dda84b1ecae65aed0548" alt="image desc"
1.4 Cloud resources required
1.5 Prerequisites
- If you’re using your own Alibaba Cloud account instead of the account provided by this lab during the experiment, please note that you’ll need to choose the same Ubuntu 16.04 operating system for your ECS, in order to run the experiment smoothly.
- Before starting the experiment, please confirm that the previous experiment has been closed normally and has been exited.
2. Start the experiment environment
Click Start Lab in the upper right corner of the page to start the experiment.
.
After the experiment environment is successfully started, the system has deployed resources needed during the experiment in the background. For example, the ECS instance, RDS instance, Server Load Balancer instance, and OSS bucket. An account consisting of the username and password for logging on to the Web console of Alibaba Cloud is also provided.
data:image/s3,"s3://crabby-images/408bc/408bc1cc4915b7d214935c5609777a4d29020c0d" alt="image desc"
After the experiment environment is started and related resources are properly deployed, the experiment starts a countdown. You have an hour to perform experimental operations. After the countdown ends, the experiment stops, and related resources are released. During the experiment, pay attention to the remaining time and arrange your time wisely. Next, use the username and password provided by the system to log on to the Web console of Alibaba Cloud and view related resources:
data:image/s3,"s3://crabby-images/9af70/9af70e9acc762c1aa1d1f130f48d239b526e4eee" alt="image desc"
Go to the logon page of Alibaba Cloud console.
data:image/s3,"s3://crabby-images/bff43/bff432342eb4a02ebfa259bd6a4b31182a97dfe6" alt="image desc"
Fill in the sub-user account and click on Next.
data:image/s3,"s3://crabby-images/e87f3/e87f35392b616cf6d200663d6f361abe9bccfd25" alt="image desc"
Fill in the sub-user password and click on Login.
data:image/s3,"s3://crabby-images/59e24/59e24106c7bd98d2298a461abb421f8d14d36846" alt="image desc"
After successfully log on to the console, you will see the page showing as the following page.
data:image/s3,"s3://crabby-images/1b7d6/1b7d6957e888a4e13fb405a23b44b1278ecdacae" alt="image desc"
3. Install Serverless Devs
Click Elastic Compute Service, as shown in the following figure.
data:image/s3,"s3://crabby-images/4f3db/4f3db9600508dfaeaf164d6c8dca10cdd55c16b7" alt="image desc"
We can see one running ECS instance in Singapore region.
Copy this ECS instance’s Internet IP address and remotely log on to this ECS (Ubuntu system) instance. For details of remote login, refer to login.
data:image/s3,"s3://crabby-images/8e2d1/8e2d113e3197e9e4f88215f0f391989575e7f8fa" alt="image desc"
The default account name and password of the ECS instance:
Account name: root
Password: nkYHG890.
After you log on to the ECS instance, run the following command to download the latest script and install and execute Serverless Devs.
curl -o- -L http://cli.so/install.sh | bash
data:image/s3,"s3://crabby-images/99c1c/99c1c9dced1e425aefc620e266fcbfd193bcdaa0" alt="image desc"
After you install Serverless Devs, run the last command in the preceding figure to make the Serverless Devs take effect.
data:image/s3,"s3://crabby-images/146b9/146b940381af6edca8c1abd6b55ada5a53300c04" alt="image desc"
Run the following command to check whether Serverless Devs is installed:
s -v
data:image/s3,"s3://crabby-images/5347b/5347b046173cb83a554fbf92d841d7381a1d4521" alt="image desc"
4.1 Create AccessKey
As shown below, click AccessKey Management.
data:image/s3,"s3://crabby-images/c5a5a/c5a5afc6866768d2279f21687650d5d9252c94e3" alt="image desc"
Click Create AccessKey. After AccessKey has been created successfully, AccessKeyID and AccessKeySecret are displayed. AccessKeySecret is only displayed once. Click Download CSV FIle to save the AccessKeySecret
data:image/s3,"s3://crabby-images/4273a/4273a53f18a805737373213e4335067fe15c3b12" alt="image desc"
4.2 Add the AccessKey pair
Go to the CLI of the ECS instance.
Run the following command to add the AccessKey pair:
s config add
data:image/s3,"s3://crabby-images/30cd0/30cd02018999b7184576ff720d44b355aa2875c4" alt="image desc"
Run the following command to view the AccessKey pair that you added:
s config get
data:image/s3,"s3://crabby-images/5ae57/5ae57836e47dc8a3d92dc74f79ea553c6942612e" alt="image desc"
4.3 Install Docker
Run the following command to update the APT installation source:
apt update
data:image/s3,"s3://crabby-images/edd72/edd727af5a537a264f5adfe633345d406103c556" alt="image desc"
Run the following command to add the GPG key of the official Docker repository to the system:
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
data:image/s3,"s3://crabby-images/9ef18/9ef18c55e52ae0128dbe0a45e4b9fe6d06ffaa8a" alt="image desc"
Run the following command to add the IP address of the Docker repository to the APT installation source:
echo "deb [arch=amd64] https://download.docker.com/linux/ubuntu xenial stable" | sudo tee -a /etc/apt/sources.list.d/docker.list
data:image/s3,"s3://crabby-images/42ac8/42ac88774c3767528074e5322ae83f818ac32222" alt="image desc"
Run the following command to update the APT installation source again:
apt update
data:image/s3,"s3://crabby-images/b3088/b30880d8a52ffd6c892980f6f4b87cd740f15a5f" alt="image desc"
Run the following command to install Docker:
apt install docker-ce -y
data:image/s3,"s3://crabby-images/4ba6a/4ba6a8ee9913ab5444bd6fce79c2c01f72f52e79" alt="image desc"
Run the following command to view the Docker status:
systemctl status docker
data:image/s3,"s3://crabby-images/e83c5/e83c53f87aec1c7c93c4cfe7e3e4f7b792720f73" alt="image desc"
Docker has been started.
Enter “q” to exit.
5. Deploy the service
Run the following command to download the sample service: It takes about 5 minutes.
s init django-blog
data:image/s3,"s3://crabby-images/27c34/27c34d4b59bc39edba10c144adf6150e69f8e441" alt="image desc"
data:image/s3,"s3://crabby-images/2e2ac/2e2ac2a85afabee7dc7412a141bb3804c39a16b2" alt="image desc"
data:image/s3,"s3://crabby-images/55de2/55de2a64a52927f20bf9da9d71e3651fdda6a6ce" alt="image desc"
Run the following command to open the s.yaml configuration file of the project:
cd django-blog
vim s.yaml
data:image/s3,"s3://crabby-images/e9105/e910563c94d8547f8bdd3c706df85bc6e56b187c" alt="image desc"
Set the region in the file to ap-southeast-1, as shown in the following figure. Save the file and exit.
data:image/s3,"s3://crabby-images/32567/32567c6f1cb4258758b50889182176da0701215c" alt="image desc"
Run the following command to deploy the project to Function Compute: It takes about 3 minutes.
s deploy
data:image/s3,"s3://crabby-images/bc13e/bc13e20c5e69bbb65e9b7d09841605cb34c546c0" alt="image desc"
data:image/s3,"s3://crabby-images/95241/95241be9f78f240a095e51c9e0951aa0c25c6f4c" alt="image desc"
Copy the domain name in the preceding figure to the browser. You can see that the service is started.
data:image/s3,"s3://crabby-images/3d702/3d702b0b508e23696281f4e81f0aca3f02c3e980" alt="image desc"
Go to the Alibaba Cloud Function Compute console, as shown in the following figure.
data:image/s3,"s3://crabby-images/fa73e/fa73e2080ef0c00999aa9e32398868b2eaa5ebb4" alt="image desc"
Select the Singapore region.
data:image/s3,"s3://crabby-images/d67d7/d67d72d2a36a3c895aeebbb6634592664be18e50" alt="image desc"
Click the service name to go to the service details page.
data:image/s3,"s3://crabby-images/b13d2/b13d2414200cc34bc637a6d6e3a9f134b18a4514" alt="image desc"
You can see that a function has been created. Click the function name to view the code of the function.
data:image/s3,"s3://crabby-images/17363/17363cd7ceae07861ad82ce97d791fa00294d979" alt="image desc"
Go back to the CLI of the ECS instance and run the following command to delete the deployed resource:
cd ~/django-blog/
s remove
data:image/s3,"s3://crabby-images/ec7b8/ec7b8ffe1e2597b834fbfc9509db44a75a34615e" alt="image desc"
data:image/s3,"s3://crabby-images/6cf60/6cf60e632149a9fe0be7ece1f119a44e5fbbd84c" alt="image desc"
Go back to the Function Compute console. You can see that the resource has been deleted.
6. Example: Building a frontend CICD
6.1 Create an SSH key pair
Run the following command and press Enter for all prompts.
ssh-keygen -t rsa
data:image/s3,"s3://crabby-images/f1a67/f1a674c4d9063f5faa5eac785ccee969e591176f" alt="image desc"
Run the following command. You can see the id_rsa private key file and the id_rsa.pub public key file. You will use the files later.
cd ~/.ssh && ls
data:image/s3,"s3://crabby-images/88336/88336e7908b2965782ee9d64e54dbb4ae44ce0fa" alt="image desc"
6.2 Create a repository
Enter the link below to enter the Alibaba Cloud code repository console.
https://codeup.aliyun.com/
create a repository as shown in the following figure.
data:image/s3,"s3://crabby-images/273fc/273fc4ff5de16c6cec42efb8282c5c0be7932bb9" alt="image desc"
Set the name of the repository.
data:image/s3,"s3://crabby-images/ba433/ba4333aea351c74ddab5e9fecdffa3d1f39e3bf6" alt="image desc"
After you create the repository, go to the project and click Settings.
data:image/s3,"s3://crabby-images/3203a/3203aeab351ee1f34aa80fe00527649c9e9ff691" alt="image desc"
Set the whitelist as shown in the following figure.
data:image/s3,"s3://crabby-images/f0399/f0399f0a3878a0e8d448bbe13674c06a0c5e0f4a" alt="image desc"
Go to Personal Settings and add the SSH public key.
data:image/s3,"s3://crabby-images/238d7/238d70ceba3da29084c0dcb6d52928f75e9bb915" alt="image desc"
How to obtain the SSH public key? Run the following command in the CLI of the ECS instance:
cat ~/.ssh/id_rsa.pub
data:image/s3,"s3://crabby-images/00767/00767b55af58771eee8063309e66d5dea8fafe11" alt="image desc"
The whitelist is added.
data:image/s3,"s3://crabby-images/3eea2/3eea2a4aa8bda48490293bb82da795de8c5667d0" alt="image desc"
Go back to the file list of the project and copy the project address.
data:image/s3,"s3://crabby-images/d90fc/d90fcd66fa602c82b10d161642b43655db1663e8" alt="image desc"
Go back to the CLI of the ECS instance. Run the following command. Replace <YOUR-SSH-URL> with your actual value.
git clone YOUR-SSH-URL
data:image/s3,"s3://crabby-images/d8bd6/d8bd68c59ffe50c20f46b41b4ab95f92c9110285" alt="image desc"
Run the following commands:
cd frontent
echo "Hello, LabEx!" > index.js
echo "Hello, LabEx2!" > index.html
data:image/s3,"s3://crabby-images/34b6d/34b6dddd7fba2b53ec69e42451968ff00052b68f" alt="image desc"
Run the following command to add a file to the workspace.
git add .
data:image/s3,"s3://crabby-images/6ebdb/6ebdb5a04fa5f36e7c2b75917c7be05a8ff3a072" alt="image desc"
Run the following command to configure the git information:
git config --global user.email "labex@aliyun.com"
git config --global user.name "labex"
data:image/s3,"s3://crabby-images/f3e7d/f3e7d6df7b40d3fe2c12763c870735ee2faf296e" alt="image desc"
Run the following command to commit the file to the repository:
git commit -m "first, prepare file"
data:image/s3,"s3://crabby-images/7b9df/7b9df484cb81c080fe63ae13ea6329b6072f2119" alt="image desc"
Run the following command to upload the file to the repository:
git push
data:image/s3,"s3://crabby-images/5321e/5321edc96adfd3851fa7ed8735ecd0c296e56bee" alt="image desc"
The file is uploaded.
data:image/s3,"s3://crabby-images/f40a8/f40a82c3fe792db4d87e21734d60280e46642914" alt="image desc"
6.3 Prepare the Object Storage Service (OSS) Environment
Go to the Alibaba Cloud OSS console, as shown in the following figure.
data:image/s3,"s3://crabby-images/501eb/501eba858e381b934aafbfbded8795fe9334c705" alt="image desc"
You can see that a bucket has been created. Click the bucket name to enter the bucket.
data:image/s3,"s3://crabby-images/1a84a/1a84a227b8e3d2f0c6148938cf5e33a7761a71c2" alt="image desc"
Click Upload to upload the file, as shown in the following figure.
data:image/s3,"s3://crabby-images/8810b/8810b6dcdd3daabcf0d68648e3d5f3efdcd90771" alt="image desc"
Create a file named my_ssh_executable.sh on your local computer. Copy the following content to the file and save the file.
#!/bin/sh
ID_RSA=/tmp/id_rsa
exec /usr/bin/ssh -o StrictHostKeyChecking=no -i $ID_RSA "$@"
Create a file named id_rsa. Copy the content in the ~/.ssh/id_rsa file to the id_rsa file and save the content.
data:image/s3,"s3://crabby-images/fa20d/fa20d10616ebee64a55b72dc5a79e223858bf7ad" alt="image desc"
Upload both files to the bucket.
data:image/s3,"s3://crabby-images/fcc86/fcc860f76d14ab97cde708a4a2383f9a35025e67" alt="image desc"
6.4 Create a function
Go to the CLI of the ECS instance.
Run the following command to install a sample project:
cd && s init start-fc-http-python3 -d start-fc-http-python3
data:image/s3,"s3://crabby-images/ac8e1/ac8e1c9453d993305efbe6dab3054857acd47c0d" alt="image desc"
data:image/s3,"s3://crabby-images/97bd1/97bd1465fcd0b8d8651cf29bbf15a0f165b9b58f" alt="image desc"
Run the following command to go to the directory of the project:
cd start-fc-http-python3 && ls
data:image/s3,"s3://crabby-images/cbaf8/cbaf8957b62e60ad35822f63af95492ac19d9e1c" alt="image desc"
Enter the vim code/index.py
command, delete the original content, and copy the following content to the index.py file and save the file. Replace <YOUR-ACCESS-KEY>, <YOUR-ACCESS-SECRET>, and <YOUR-BUCKET-NAME> with your actual values.
# -*- coding: utf-8 -*-
import oss2
import subprocess
import os
import time
import ast
import shutil
HELLO_WORLD = b'200 OK!\n'
def handler(environ, start_response):
# Configure OSS access endpoints
endpoint = 'oss-ap-southeast-1-internal.aliyuncs.com'
# Configure bucket name
bucketname = 'YOUR-BUCKET-NAME'
# To configure accessKeyId and accessKeySecret, you need to have read and write OSS permissions
accessKeyId = 'YOUR-ACCESS-KEY'
accessKeySecret = 'YOUR-ACCESS-SECRET'
auth = oss2.Auth(accessKeyId, accessKeySecret)
bucket = oss2.Bucket(auth, endpoint, bucketname)
# Download the sshkey private key file from OSS
bucket.get_object_to_file('id_rsa', '/tmp/id_rsa')
# Download the custom executable file from OSS and select the specified sshkey public key file
bucket.get_object_to_file('my_ssh_executable.sh', '/tmp/my_ssh_executable.sh')
# Modify file permissions
subprocess.Popen(['chmod 0600 /tmp/id_rsa'], shell=True)
subprocess.Popen(['chmod +x /tmp/my_ssh_executable.sh'], shell=True)
# get request_body
try:
request_body_size = int(environ.get('CONTENT_LENGTH', 0))
except (ValueError):
request_body_size = 0
request_body = environ['wsgi.input'].read(request_body_size)
request_body = request_body.decode()
print (request_body)
# json formatted object
request_body = ast.literal_eval(request_body)
# get branch
branch = request_body.get('ref').split('/')[-1]
# get sshurl
sshurl = request_body.get('repository').get('git_ssh_url')
# sshurl = request_body.get('html_url')
# get repository name
repositoryname = request_body.get('repository').get('name')
print (branch, sshurl, repositoryname)
localpath = '/tmp/{}'.format(repositoryname)
# delete existing directory
if os.path.exists(localpath):
shutil.rmtree(localpath)
if os.path.exists("/tmp/my_ssh_executable.sh") and os.path.exists("/tmp/id_rsa"):
print("id_rsa and ssh_executable.sh config exists")
else:
print("not exists\n")
# Use the specified sshkey public key file to download the corresponding branch code file and store it in the /tmp directory
gitclone = 'cd /tmp; GIT_SSH="/tmp/my_ssh_executable.sh" git clone -b {b} {u}'.format(b=branch, u=sshurl)
print(gitclone)
try:
out_bytes = subprocess.check_output([gitclone], shell=True, timeout=10)
except subprocess.CalledProcessError as e:
out_bytes = e.output # Output generated before error
code = e.returncode # Return code
# Traverse all files in the download branch and upload to OSS
rt = subprocess.Popen(['find {localpath} -type f ! -path "{localpath}/.git/*"'.format(localpath=localpath)],
shell=True, stdout=subprocess.PIPE)
files = rt.stdout.readlines()
for f in files:
localfile = f.decode().replace("\n", "")
ossfile = localfile.replace(localpath, repositoryname, 1)
print (localfile, ossfile)
if os.path.isfile(localfile):
bucket.put_object_from_file(ossfile, localfile)
# do something here
status = '200 OK'
response_headers = [('Content-type', 'text/plain')]
start_response(status, response_headers)
return [HELLO_WORLD]
data:image/s3,"s3://crabby-images/69f41/69f41f68e1eaee3b04dbe41b9f053a4df7308466" alt="image desc"
Run the vim s.yaml
command to open the configuration file. Modify the configuration file, as shown in the following figure.
data:image/s3,"s3://crabby-images/0e9ca/0e9cafac7a13f3265a59a3fa9ad4398e985a92ea" alt="image desc"
Run the following command to deploy the service to Function Compute:
s deploy
data:image/s3,"s3://crabby-images/bfd3e/bfd3e2f7183c3943feddf2ca04f7da4833269d80" alt="image desc"
data:image/s3,"s3://crabby-images/b11f7/b11f7abb6e22466574d39a81098ef71df19417b0" alt="image desc"
Go to the Alibaba Cloud Function Compute console and select the Singapore (Singapore) region.
data:image/s3,"s3://crabby-images/cdb47/cdb473af62330efe5497b9abbcb99b10e393cc46" alt="image desc"
data:image/s3,"s3://crabby-images/a73e9/a73e938aca51b3c8925d5ae97c096548c13f6502" alt="image desc"
You can see that the code has been deployed.
data:image/s3,"s3://crabby-images/3dd76/3dd765541642cefaffeeb87f8b347b7509968e86" alt="image desc"
Copy the trigger address of the function.
data:image/s3,"s3://crabby-images/5f62e/5f62eb5d3796c62235262fc926aa2d97edf4bff8" alt="image desc"
Copy the address to the webhook of your repository.
data:image/s3,"s3://crabby-images/c26be/c26be103aa6c0ada597ac29f8ec7eff5a14346cf" alt="image desc"
data:image/s3,"s3://crabby-images/59adb/59adb8e09b2a60c88ee3086e99090ea124b9823a" alt="image desc"
The trigger address is added.
data:image/s3,"s3://crabby-images/3a79b/3a79b023e7789e10062e64004bc9dfac1b2afe0b" alt="image desc"
Go back to the Alibaba Cloud Function Compute console and modify the configurations of the hello-world-service project.
data:image/s3,"s3://crabby-images/e7912/e791214af3f8a417ce449a869796cc4b1d94d75a" alt="image desc"
Allow the function to access the Internet.
data:image/s3,"s3://crabby-images/7d92e/7d92e3f85941a0e188fd0e8bfb1b4980525373be" alt="image desc"
6.5 Test
Go back to the CLI of the ECS instance. Run the following command to modify a file and upload it to the repository:
cd ~/frontent && echo "Hello, LabEx test" >> "index.js"
git add .
git commit -m "add test"
git push
data:image/s3,"s3://crabby-images/3e5f2/3e5f2ae3fc10c8ab539c9a6594dd31ae985117a8" alt="image desc"
Go to the Alibaba Cloud OSS console. You can see that the frontent repository has been synchronized to the bucket.
data:image/s3,"s3://crabby-images/29aa9/29aa9da5d400f72cf757cb369a42a3349ea4b967" alt="image desc"
data:image/s3,"s3://crabby-images/3787d/3787d7aaa73f7a09a7913e7882ae41ac447b71ad" alt="image desc"
Obtain the URL of the bucket.
data:image/s3,"s3://crabby-images/b2fa4/b2fa429972429a617568be3cc1ea043e0e16b403" alt="image desc"
Copy the URL to your browser. Add the path /frontend/index.js to the end of the URL to access the bucket.
data:image/s3,"s3://crabby-images/bd91c/bd91cc80406f4ceb8910e619e87c1e634b679b95" alt="image desc"
Reminder:
Before you leave this lab, remember to log out your Alibaba RAM account before you click the Stop button of your lab. Otherwise, you’ll encounter some issues when opening a new lab session in the same browser:
data:image/s3,"s3://crabby-images/a1dbb/a1dbb117391df469534486354c59fb85c57ba59e" alt="image desc"
data:image/s3,"s3://crabby-images/72fb8/72fb856c272066ef3b466c977e1bd7b2bf5565bc" alt="image desc"
7. Experiment summary
This experiment describes how to use Serverless Devs to manage Function Compute resources. Serverless Devs allows users to use serverless services and frameworks in a pluggable manner and develop components and plug-ins. This improves the efficiency of O&M. Serverless Devs also allows users to efficiently develop, create, test, and deploy an application and to manage the full lifecycle of the application.