Automatically Process OSS Images Using Function Compute
1. Experiment
1.1 Knowledge points
This experiment uses Alibaba Cloud Function Compute and OSS. We will write image processing code in Function Compute, then we uploaded images in OSS. Image uploading will automatically trigger code in Function Compute for automatic image processing.
Alibaba Cloud Function Compute is a fully-managed and event-driven computing service that allows you to focus on writing and uploading code without having to manage infrastructure such as servers. Function Compute prepares the computing resources for you and executes your code elastically and reliably, while offering a range of features like log queries, performance monitoring, and alarms.
1.2 Experiment process
- Prepare OSS environment
- Create functions
- Create triggers
- Demonstrate effects
1.3 Cloud resources required
1.4 Prerequisites
- Learn about Python
- Learn about OSS
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 required by this experiment in the background, including 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/a458b/a458bbce69314bbff9600cbec260468df83ae777" alt="image desc"
After the experiment environment is started and related resources are properly deployed, the experiment starts a countdown. You have two hours 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/a0da1/a0da1a194cee7342d87baa97cf4ad513f0c2a97f" alt="openCole"
Go to the logon page of Alibaba Cloud console.
data:image/s3,"s3://crabby-images/bdd88/bdd885f4f332e53c4c8f0947d061ef8935051f27" alt="image desc"
Fill in the sub-user account and click Next.
data:image/s3,"s3://crabby-images/068c3/068c31a067596fd898385d32c4de1880ba3a7f6d" alt="image desc"
Fill in the sub-user password and click Log on.
data:image/s3,"s3://crabby-images/bc761/bc761a6d7e7c6e417834d2b8f2cc28e346a76d92" alt="image desc"
After you successfully log on to the console, the following page is displayed.
data:image/s3,"s3://crabby-images/1b7d6/1b7d6957e888a4e13fb405a23b44b1278ecdacae" alt="image desc"
3. Prepare OSS environment
Click Products in the upper-left corner. Choose Object Storage Service.
data:image/s3,"s3://crabby-images/ffc22/ffc22f8949d88f659c3da0139ef142ef95ad28f8" alt="image desc"
We can see that a bucket has already been created (your bucket name may be different).
data:image/s3,"s3://crabby-images/23585/23585b8fe05f094029a6d05979d00ecaca0510c4" alt="image desc"
Click on the name of this bucket, select Basic Settings and click Edit in the Static Page section
data:image/s3,"s3://crabby-images/c172c/c172c2d62e2228b25bff7b99af6c728412e189e7" alt="image desc"
Set “index.html” as the Default Homepage and click Save, as shown in the screenshot below.
data:image/s3,"s3://crabby-images/27a9b/27a9b8965dc00fd33947c8471f0143f924f1baea" alt="image desc"
Select Files and click Create Directory to create a directory named “source”.
data:image/s3,"s3://crabby-images/5653f/5653fe958502257e3be20e8475c73ca3371ad30e" alt="image desc"
Similarly, create the directories “processed” and “backup”.
data:image/s3,"s3://crabby-images/4c7c2/4c7c2b7e9c6af646cd606818087269286bdc10d0" alt="image desc"
Now the OSS environment is ready.
4. Create a Function Compute service
Select Function Compute.
data:image/s3,"s3://crabby-images/7ff8c/7ff8ca228e82cda94cef71122b36b189346cff4e" alt="image desc"
Select the US(Silicon Valley) region.
data:image/s3,"s3://crabby-images/13369/133698929cbbcd3fd0c24c8b3db873b73f4a4b32" alt="image desc"
设置服务名,并取消绑定日志,点击 Next。
data:image/s3,"s3://crabby-images/d12a9/d12a95f4b9510491f04030b48a7ac2081ea32b77" alt="image desc"
Select Event Function and click Next.
data:image/s3,"s3://crabby-images/12465/12465fa0bea775996754f8632f9e29bf8f6860e1" alt="image desc"
Set up the service called “labex-service”, the function is called “labex-image-disposal”, running environment for “python2.7”, click on the Create. Please remove the check of Bind Log, the log function will not be used temporarily.
data:image/s3,"s3://crabby-images/cdf32/cdf32d99b0802c1933c975b9116d3432d5394c99" alt="image desc"
data:image/s3,"s3://crabby-images/55f89/55f89f54674f50c64d32d63c20e6f7290340175c" alt="image desc"
Add the code for the current function. Remove the sample code, copy the following code to enter, and click Save.
# -*- coding: utf-8 -*-
import json,oss2
def handler(event, context):
evt = json.loads(event)
endpoint = 'oss-{0}.aliyuncs.com'.format(evt['events'][0]['region'])
creds = context.credentials
auth = oss2.StsAuth(creds.accessKeyId, creds.accessKeySecret, creds.securityToken)
bucket = oss2.Bucket(auth, endpoint, evt['events'][0]['oss']['bucket']['name'])
objectName = evt['events'][0]['oss']['object']['key']
if objectName.find("dog") > -1:
style = 'image/watermark,type_d3F5LXplbmhlaQ,size_30,text_SGVsbG8sRG9nISE=,color_FFFFFF,shadow_50,t_100,g_se,x_10,y_10'
elif objectName.find("cat") > -1:
style = 'image/watermark,type_d3F5LXplbmhlaQ,size_30,text_SGVsbG8sQ2F0ISE=,color_FFFFFF,shadow_50,t_100,g_se,x_10,y_10'
else:
style = 'image/watermark,type_d3F5LXplbmhlaQ,size_30,text_SGVsbG8sTGFiZXghIQ==,color_FFFFFF,shadow_50,t_100,g_se,x_10,y_10'
newObjectName = objectName.replace("source","processed")
object_stream = bucket.get_object(objectName, process = style)
bucket.put_object(newObjectName, object_stream)
remote_stream = bucket.get_object("index.html")
content = ""
flag = 0
for line in remote_stream.read().split("\n"):
if line.find(newObjectName) > -1:
flag = 1
break
else:
content = content + line + "\n"
if flag == 0:
insert = """<div> <img src="%s" height="200" width="300" /> </div>""" % (newObjectName)
res = ""
for line in content.split("\n"):
if line.find("<!-- -->") > -1:
res = res + insert + "\n"
res = res + line + "\n"
bucket.put_object("index.html",res)
return "labex"
data:image/s3,"s3://crabby-images/62486/62486b542f95c2de7c7f44dfb7ffe91f124f3fc1" alt="image desc"
Select Service-function and click Create again.
data:image/s3,"s3://crabby-images/ee5e3/ee5e3d47fc1ea530689acdb96fa1d788ff37275b" alt="image desc"
Click Event Function.
data:image/s3,"s3://crabby-images/9f481/9f4819cdfcd831c0d8bb386268f7bc2baeac0e8d" alt="image desc"
Name of service select “labex-service” set when first created, and set the function name to “labex-image-delete”, click Create.Please remove the check of Bind Log, the log function will not be used temporarily.
data:image/s3,"s3://crabby-images/5162b/5162ba63b34ae5d0e69070e1f2a933b54430ca3f" alt="image desc"
Then copy in the following code and click Save.
# -*- coding: utf-8 -*-
import json,oss2
def handler(event, context):
evt = json.loads(event)
endpoint = 'oss-{0}.aliyuncs.com'.format(evt['events'][0]['region'])
creds = context.credentials
auth = oss2.StsAuth(creds.accessKeyId, creds.accessKeySecret, creds.securityToken)
bucket = oss2.Bucket(auth, endpoint, evt['events'][0]['oss']['bucket']['name'])
objectName = evt['events'][0]['oss']['object']['key']
old_objectName = objectName.replace("source","processed")
bucket.delete_object(old_objectName)
remote_stream = bucket.get_object("index.html")
content = ""
for line in remote_stream.read().split("\n"):
if line.find(old_objectName) == -1:
content = content + line + "\n"
bucket.put_object("index.html", content)
return "labex"
data:image/s3,"s3://crabby-images/a6dd3/a6dd365c148bed812babda67f3be5afdf9a71b7e" alt="image desc"
Create a third function as shown above. Select “labex-service” for the service name, set the function name to “labex-image-backup”, and copy in the following code. Note that you should replace “YOUR-BUCKET-NAME” in the following code with your own bucket name.
# -*- coding: utf-8 -*-
import json,oss2,time
from itertools import islice
def handler(event, context):
endpoint = "oss-us-west-1.aliyuncs.com"
bucket_name = "YOUR-BUCKET-NAME"
creds = context.credentials
auth = oss2.StsAuth(creds.accessKeyId, creds.accessKeySecret, creds.securityToken)
bucket = oss2.Bucket(auth, endpoint, bucket_name)
timestr = time.strftime('%Y%m%d%H%M',time.localtime(time.time()))
for b in oss2.ObjectIterator(bucket, prefix = 'processed'):
filename = b.key
if filename.find(".png") > -1:
print filename
filename_stream = bucket.get_object(filename)
bucket.put_object("backup/"+ timestr + "/" + filename, filename_stream)
return "labex"
data:image/s3,"s3://crabby-images/4686b/4686b0dae65774117ff1d7650b6373183df7c190" alt="image desc"
Finally, you can see that under labex-service service, there are three functions.
data:image/s3,"s3://crabby-images/9cf82/9cf826fac2b1b9732181207acf4c79561b8f8a34" alt="image desc"
Select Service Configurations , Click Modify Configuration.
data:image/s3,"s3://crabby-images/33219/3321993219072c523d01cce8f07037f2f87791a4" alt="image desc"
Select Role Config, and click Create Role.
data:image/s3,"s3://crabby-images/d96b3/d96b3d1193ba5b7c8fce0f3edf1cc7f7f0e9248c" alt="image desc"
Click Confirm Authorization Policy.
data:image/s3,"s3://crabby-images/a4c6d/a4c6d12fce8f17a03adb0d8277ce3b19a1275ba7" alt="image desc"
Click Add Policy。
data:image/s3,"s3://crabby-images/cab70/cab701a33f07988c36b0cf374d73f5450ad1e13b" alt="image desc"
data:image/s3,"s3://crabby-images/c2a61/c2a61bb7d7f9bf139879c5a4803849fb9b3aee7c" alt="image desc"
Click Submit.
data:image/s3,"s3://crabby-images/b6e98/b6e9871011037b338101586256f7d7e344f12d35" alt="image desc"
The configuration is complete.
data:image/s3,"s3://crabby-images/ca8f0/ca8f07cda903e5ecf200e77d2859b945e219018f" alt="image desc"
5. Add OSS function triggers
5.1 Create an OSS object creation trigger
Choose labex-image-disposal function,
data:image/s3,"s3://crabby-images/491ef/491efa855c178d4df23a5b54e70eba2a4b355e9c" alt="image desc"
Click Create Trigger with the image below.
data:image/s3,"s3://crabby-images/84a39/84a395848399d0088a2c582c23b30fd93714ddc9" alt="image desc"
Refer to below setting, set to “disposal-trigger” trigger name.
data:image/s3,"s3://crabby-images/e0d20/e0d20e5b0580b5fd57327db5ffc6766e7a59550d" alt="image desc"
Go Quick authorize. Click authorize.
data:image/s3,"s3://crabby-images/764b2/764b27604e8c946cdb36737a0bff7509d31a983e" alt="image desc"
data:image/s3,"s3://crabby-images/af392/af392af8337024d88d64823aa74f608a00a71cbb" alt="image desc"
Creation is complete.
data:image/s3,"s3://crabby-images/71df3/71df313f70c4aa4b3366ccc3fc4cb701062b3f4a" alt="image desc"
data:image/s3,"s3://crabby-images/5cee2/5cee249fed58291b6420e5450a00c1d6b8adc59c" alt="image desc"
5.2 Create an OSS object deletion trigger
Select the labex-image-delete function.
data:image/s3,"s3://crabby-images/b5590/b55909495d076e7ec78025d32b4091d628158674" alt="image desc"
Click Create Trigger.
data:image/s3,"s3://crabby-images/21187/211870ecc3bb76c845e8779d71ad094f6c03fec3" alt="image desc"
With the trigger name “delete-trigger”, click OK.
data:image/s3,"s3://crabby-images/c1a8d/c1a8debedb19cc0f2d4797ac398f869f4d5af544" alt="image desc"
Creation is complete.
data:image/s3,"s3://crabby-images/ea048/ea048452a3878e338ed472d12f74af8a4108802e" alt="image desc"
5.3 Create an OSS object timing trigger
Select the labex-image-backup function.
data:image/s3,"s3://crabby-images/b3a43/b3a43507551ddea6181019989d902cf0d2bd5fe1" alt="image desc"
Refer to the Settings in the figure below. The trigger name is “timing trigger” and click OK.
data:image/s3,"s3://crabby-images/51fc4/51fc48e13e6db84d2520419953df600c59da432d" alt="image desc"
The creation is complete, but the current state is not in effect.
data:image/s3,"s3://crabby-images/d68dd/d68dd009997a155e0dac2fbb7d25a47fb825f289" alt="image desc"
6. Demonstrate effects
6.1 Install nginx reverse proxy
Because the webpage type file (mimetype is text / html, extensions include htm, html, jsp, plg, htx, stm) in the bucket is accessed using the oss default domain name, Content-Disposition: ‘attachment = filename; ‘. That is, when accessing a web page type file from a browser, the file content is not displayed, but is downloaded as an attachment, but we need to show the effect on the browser.
So we need to do it through the nginx reverse proxy. In the proxy, nginx can modify the value of the Response Header so that the browser will not download the web page type file, but directly display the file content in the browser.
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 Silicon Valley region.
data:image/s3,"s3://crabby-images/0390a/0390a5ac3bbbc1cbd05e80473102bb3d89bbd7bc" alt="image desc"
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/c1cc7/c1cc7357d3ceda7a4e94b6d7676b9347182df8f7" alt="image desc"
The default account name and password of the ECS instance:
Account name: root
Password: nkYHG890..
After successful login, enter the following command to update the apt installation source.
apt update
data:image/s3,"s3://crabby-images/77a9b/77a9b03402de7efd2ef3b67db6b9923f5029c1d3" alt="image desc"
Enter the following command to install nginx.
apt -y install nginx
data:image/s3,"s3://crabby-images/40d2b/40d2bae047358d00d3b181ea24a65b895cf7a366" alt="image desc"
Enter the command vim default
, create a new default file, copy the following content into the file, save and exit. Please replace the YOUR-BUCKET-DOMAIN below with your own
server {
listen 80;
location / {
proxy_pass http://YOUR-BUCKET-DOMAIN;
}
proxy_hide_header 'Content-Disposition';
add_header 'Content-Disposition' 'inline';
}
data:image/s3,"s3://crabby-images/75418/75418fb46de5c7fc1dfc169db99d569ebf908c6d" alt="image desc"
Way to get YOUR-BUCKET-DOMAIN.
data:image/s3,"s3://crabby-images/e7fed/e7fed181b6b1675a0c3f5b6fa083364b2b8f78ce" alt="image desc"
Enter the following command to move the configuration file to the nginx configuration directory and restart the nginx service.
mv default /etc/nginx/sites-available
service nginx restart
data:image/s3,"s3://crabby-images/be66e/be66eada3529d4f72801399b929a545e0ba97b99" alt="image desc"
Enter the following command and see that port 80 has been started, indicating that nginx was successfully installed.
netstat -utnlp
data:image/s3,"s3://crabby-images/34acd/34acd1b22440e314eb02069ae24955d41468d936" alt="image desc"
6.2 effects
Click the example images to download reference images.
Decompress the downloaded zip package. We get nine images and one “index.html” file.
Click Upload to upload the “index.html” file to the root directory of your bucket
data:image/s3,"s3://crabby-images/51081/51081ddcb08f944eafc895147e1b5701468aca06" alt="image desc"
Now, let’s take a look at the roles of the “index.html” file and these directories.
The “index.html” file makes it easier to display images under the “processed” directory. The file’s content is shown as follows.
<html>
<head>
<title>Hello OSS! </title>
<meta charset="utf-8">
<style>div{display:inline-block;}</style>
</head>
<body>
<h1> hello labex!! </h1>
<!-- -->
</body>
</html>
When you upload these downloaded images to the “source” directory, the “disposal-trigger” trigger previously created in Step 6.1 will trigger
the “labex-image-disposal” function. This function will perform two tasks:
1. Process these uploaded images and store the processed images in the "processed" directory
2. Modify the index.html content and add the paths of the images added to the "processed" directory
When you delete files under the “source” directory, the trigger previously created in Step 6.2 will trigger the labex-image-delete function. This function will also perform two tasks:
- Delete images in the “processed” directory accordingly
- Modify the index.html content and delete the paths of images that are deleted from the “processed” directory
The timing-trigger previously created in Step 6.3 is a timing trigger that triggers the labex-image-backup function every three minutes. This function will back up files under the “processed” directory to the “backup” directory.
Now let’s proceed with this experiment
Click the “source” directory to access the folder, and click Upload
data:image/s3,"s3://crabby-images/ecb69/ecb695efeb12d4975cc252fecdc12fd83c669374" alt="image desc"
After files are uploaded,
data:image/s3,"s3://crabby-images/72a59/72a598d62afba9faff8ca69c5848c39a8ef19b0c" alt="image desc"
click the return arrow icon shown in the screenshot above to go back to the upper level directory, and then go to the “processed” directory. As we can see, images that were uploaded to the “source” directory are also stored in the “processed” directory, indicating that the trigger has successfully triggered the “labex-image-disposal” function.
data:image/s3,"s3://crabby-images/97b2d/97b2d00ba52d2773b52888ad71836d1e152c2939" alt="image desc"
Next, we enter the following link in the browser, please pay attention to replace YOUR-ECS-PUBLIC-IP with the user’s own ECS The public IP of the instance.
http://YOUR-ECS-PUBLIC-IP:80/index.html
We can see that each uploaded image has a unique watermark automatically added
data:image/s3,"s3://crabby-images/21c2c/21c2c27778833c16a267a3902958bd7646b2ecb9" alt="image desc"
Go back to the “source” directory and delete the image “dog1”. (You can delete as many images as you want. However, you can only delete one image at a time. The batch deletion of several images will cause multiple trigger functions to be simultaneously executed on the “index.html” file. As a result, the “index.html” page may fail to show images as expected.)
data:image/s3,"s3://crabby-images/53b1f/53b1f164324607053123fdfdc76d430aa7e4008c" alt="image desc"
Refresh the browser page. We can see the number of images displayed in the webpage is reduced by 1, indicating that the “labex-image-delete” was successfully triggered. The corresponding image under the “processed” directory is also deleted. You can go to the “processed” directory to verify.
data:image/s3,"s3://crabby-images/7e084/7e0845f43a9ba44ca9ddcc6ef90f6a2c49ae3789" alt="image desc"
<font color='red'>Users can cut off the above result picture when they are doing the experiment and send it to the teacher, indicating that the current experiment has been completed.</font>
Now we can go back to the Function Compute service console and enable the “timing-trigger” trigger that was disabled in Step 6.3.
data:image/s3,"s3://crabby-images/0260e/0260e37d497a86d4d77aa9f74cf2e381702b7941" alt="image desc"
Return to the console of the OSS bucket and go to the “backup” directory. We can see that the directory doesn’t contain any backup files.
data:image/s3,"s3://crabby-images/8a8ef/8a8ef9bc80340199e54f446cac8b872ba8711c08" alt="image desc"
This is because we have specified a backup interval of three minutes. Wait for 3 minutes and we can see that a backup directory was created. This indicates that the “labex-image-backup” was successfully triggered.
data:image/s3,"s3://crabby-images/001c1/001c188db62e924f23061b4d70b96801ca5db91e" 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 issue when opening a new lab session in the same browser:
data:image/s3,"s3://crabby-images/f5779/f5779d319bac3a2f6a12dcceedc8250237297ecc" alt="image desc"
7. Experiment summary
Alibaba Cloud’s Function Compute and OSS services are used in this experiment. This experiment describes how to automatically process and backup images stored in OSS
by creating functions and OSS triggers on the Function Compute service and using the OSS image processing SDK. Using Function Compute, you only need to deploy code to Function Compute and trigger function execution in a event-driven manner before the image processing service can run as expected. This can significantly reduce M&O cost since infrastructure like servers no longer need to be purchased or managed.