Project Standard

Two minimal requrements:

  • packages directory
  • project.yml

packages directory standard

The directory specification of packages is the same as the directory specification of your Function, for example, I created this Function:

Figure 1:An Digital Ocean Function Creation

那么对应的 package 目录就为:

  1. [root@liqiang.io]# tree
  2. .
  3. ├── packages
  4. └── test-package
  5. └── functiona
  6. └── main.go
  7. └── project.yml

The packages directory is allowed to contain multiple Functions, so just follow this standard.

project.yml standard

Here is a straightforward project configuration file with all the properties.

  1. parameters:
  2. param1: value
  3. environment:
  4. env1: value
  5. packages:
  6. - name: package1
  7. parameters: {}
  8. environment: {}
  9. annotations: {}
  10. actions:
  11. - name: function1
  12. parameters: {}
  13. environment: {}
  14. limits: {}
  15. runtime: 'go:default'
  16. main: ''

You can see that the overall structure is three-tiered.

  • The first level: the project level, where a project contains multiple packages, and the properties defined at the project level are inherited by the packages.
  • The second level: package level, where a package contains multiple functions, and the properties defined at the package level will also be inherited by functions (including, of course, properties inherited from the project).
  • The third level: the function level, which defines special properties belonging to this function.

generic functions

As you can see, all three levels have parameters and environment as parameters.

parameters

The properties defined in parameters are passed to Function as parameters, for example, the entry interface of Function is as follows.

  1. func Main(args map[string]interface{}) map[string]interface{} {

Then these defined arguments are all part of args.

environment

This is the clichéd environment variable, so I won’t go into it.

Function Parameters

main

The main parameter defines the entry point of Function. You may wonder why you need to customize it when the entry point is Main. It’s actually quite simple, Main is the default entry, if you don’t define it, then use it, if you need to customize it, you can define it with the main parameter.

runtime

runtime is used to define the application runtime, for example, I use go, so I define go as the runtime, but go has different versions, so you can specify the version of go, the default is go:default, specify the version is similar to: go:1.18.

limits

The limits field is used to limit some properties of the Function, the following properties are currently supported.

  • timeout: unit: ms, used to limit the response time of the API.
  • memory: unit: MB, used to limit the memory used by the program.
  • logs: unit: KB, used to limit the size of the program’s logs.

Some lessons learned

  • Function code can only be in a single directory
    • My guess: Function is positioned as a function, not a project, so it shouldn’t be very large, and a single-level directory will satisfy the requirement
    • My guess: Function is a business unit, and when you need to build a more complex structure in layers, you need to combine different Functions to complete it.
  • The feeling is that Digital Ocean’s Function is really young, and the first public function is still very limited, but I know that there are definitely not only so many supported, but in fact there are only so many that I can know how to use.