Deploying a Microservice Using Source Code
Scenarios
ServiceStage allows you to quickly deploy microservices in containers (such as CCE) or VMs (such as ECS), and supports source code deployment, JAR/WAR package deployment, and Docker image package deployment. In addition, ServiceStage allows you to deploy, upgrade, roll back, start, stop, and delete applications developed in different programming languages, such as Java, PHP, Node.js, and Python.
In this practice, backend components developed in Java and frontend components developed in Node.js are used.
User Story
- Frontend component: weathermapweb, which is developed in Node.js.
- Backend components: weather, fusionweather, forecast, and edge-service, which are developed based on Java.
The procedures for deploying a microservice are as follows:
Creating and Deploying a Backend Application Component
You need to create and deploy four application components (weather, forecast, fusionweather, and edge-service), which correspond to the four software packages generated by the backend build jobs.
- Log in to ServiceStage.
- Choose Application Management.
- Click Create Component in the Operation column of the application created in Creating an Application (for example, weathermap).
- In the Basic Information area, set the following mandatory parameters. Retain the default values for other parameters.
Parameter
Description
Component Name
Enter the name of the corresponding backend component (for example, weather).
Component Version
Click Generate. By default, the version number is generated based on the time when you click Generate. The format is yyyy.mmdd.hhmms, where s is the ones place of the second in the timestamp. For example, if the timestamp is 2022.0803.104321, the version number is 2022.0803.10431.
Application
Select the application created in Creating an Application, for example, weathermap.
Environment
Select the environment created in Creating an Environment, for example, env-test.
Namespace
Select default to isolate component instances.
- In the Component Package area, set the following mandatory parameters. Retain the default values for other parameters.
Parameter
Description
Stack
Select Java.
Source Code/Software Package
- Select Source code repository.
- Select GitHub.
- Authorization: Select the authorization information created in Setting GitHub Repository Authorization.
- Username/Organization: Select the GitHub account created when Registering a GitHub Account and Forking the Weather Forecast Source Code.
- Repository: Select the weather forecast source code repository that has been forked to your GitHub account when Registering a GitHub Account and Forking the Weather Forecast Source Code. For example, weathermap.
- Branch: Select master.
- In the Build Job area, set mandatory build parameters.
- Dockerfile Address: Set this parameter by referring to the following table.
Component Name
Dockerfile Address
weather
./weather/
forecast
./forecast/
fusionweather
./fusionweather/
edge-service
./edge-service/
- Organization: Select the organization created in Creating an Organization.
- Environment: Select Use current environment. Use the CCE cluster in the deployment environment to which the component belongs to build an image. In the current environment, masters and nodes in the CCE cluster must have the same CPU architecture. Otherwise, the component build fails.
- Namespace: Select default to isolate build data.
- Retain the default values for other parameters.
Figure 1 Configuring build parameters
- Dockerfile Address: Set this parameter by referring to the following table.
- Click Next.
- In the Resources area, set Instances for each component and retain the default values for other parameters.
Component Name
Instances
weather
2
forecast
1
fusionweather
1
edge-service
1
- Bind the ServiceComb engine.
- After a component is deployed, the microservice will be registered with the bound ServiceComb engine.
- All components must be registered with the same ServiceComb engine.
- Choose Cloud Service Settings > Microservice Engine.
- Click Bind Microservice Engine.
- Select the managed exclusive ServiceComb engine in the current environment.
- Click OK.
- Click Create and Deploy.
Setting the Access Mode of the edge-service Component
- Click in the upper left corner to return to the Application Management page.
- Click the application created in Creating an Application (for example, weathermap). The Overview page is displayed.
- In the Component List area, locate the row that contains edge-service and click View Access Mode in the External Access Address column.
- Click Add Service in the TCP/UDP Route Configuration area and set parameters by referring to the following table.
Parameter
Description
Service Name
Retain the default value.
Access Mode
Select Public network access.
Access Type
Select Elastic IP address.
Service Affinity
Retain the default value.
Protocol
Select TCP.
Container Port
Enter 3010.
Access Port
Select Automatically generated.
Figure 2 Setting the access mode of the edge-service component
- Click OK.
Creating and Deploying a Frontend Component
- Click in the upper left corner to return to the Application Management page.
- Click Create Component in the Operation column of the application created in Creating an Application (for example, weathermap).
- In the Basic Information area, set the following mandatory parameters. Retain the default values for other parameters.
Parameter
Description
Component Name
Enter the frontend component name weathermapweb.
Component Version
Click Generate. By default, the version number is generated based on the time when you click Generate. The format is yyyy.mmdd.hhmms, where s is the ones place of the second in the timestamp. For example, if the timestamp is 2022.0803.104321, the version number is 2022.0803.10431.
Application
Select the application created in Creating an Application, for example, weathermap.
Environment
Select the environment created in Creating an Environment, for example, env-test.
Namespace
Select default to isolate component instances.
- In the Component Package area, set the following mandatory parameters. Retain the default values for other parameters.
Parameter
Description
Stack
Select Node.js.
Source Code/Software Package
- Select Source code repository.
- Select GitHub.
- Authorization: Select the authorization information created in Setting GitHub Repository Authorization.
- Username/Organization: Select the username used to log in to GitHub in Registering a GitHub Account and Forking the Weather Forecast Source Code.
- Repository: Select the weather forecast source code repository that has been forked to your GitHub account. For example, weathermap.
- Branch: Select master.
- In the Build Job area, set mandatory build parameters.
- Dockerfile Address: Set this parameter by referring to the following table.
Component Name
Dockerfile Address
weathermapweb
./weathermapweb/
- Organization: Select the organization created in Creating an Organization.
- Environment: Select Use current environment. Use the CCE cluster in the deployment environment to which the component belongs to build an image. In the current environment, masters and nodes in the CCE cluster must have the same CPU architecture. Otherwise, the component build fails.
- Namespace: Select default to isolate build data.
- Retain the default values for other parameters.
- Dockerfile Address: Set this parameter by referring to the following table.
- Click Next to add an environment variable.
- Choose Container Settings > Environment Variable.
- Click Add Environment Variable to configure environment variables.
Type
Name
Variable/Variable Reference
Add manually
SERVICE_ADDR
Access address generated in Setting the Access Mode of the edge-service Component.
- Click Create and Deploy.
Confirming the Deployment Result
- Click in the upper left corner to return to the Application Management page.
- Choose Cloud Service Engine > Microservice Catalog.
- Select the ServiceComb engine where the microservice application is deployed from the Microservice Engine drop-down list.
- Select the application (for example, weathermap) created in Creating an Application from Microservice List.
If the number of instances of each microservice is the same as listed in the following table, the deployment is successful.
Component Name
Instances
weather
2
forecast
1
fusionweather
1
edge-service
1
Setting the Access Mode
- Choose Application Management.
- Click the application created in Creating an Application (for example, weathermap). The Overview page is displayed.
- In the Component List area, locate the row that contains weathermapweb and click View Access Mode in the External Access Address column.
- Click Add Service in the TCP/UDP Route Configuration area and set parameters by referring to the following table.
Parameter
Description
Service Name
Retain the default value.
Access Mode
Select Public network access.
Access Type
Select Elastic IP address.
Service Affinity
Retain the default value.
Protocol
Select TCP.
Container Port
Enter 3000.
Access Port
Select Automatically generated.
Figure 3 Setting the access mode
- Click OK.
Figure 4 Access address
Accessing an Application
- Click in the upper left corner to return to the Application Management page.
- Click the application created in Creating an Application (for example, weathermap). The Overview page is displayed.
- In the Component List area, locate the row that contains weathermapweb and click View Access Mode in the External Access Address column.
If the following page is displayed, the weather forecast microservice application is successfully deployed.
Figure 5 Application deployed successfully
- The data is real-time data.
- When you access the application for the first time, it takes some time for the weather system to be ready. If the preceding page is not displayed, refresh the page.
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.See the reply and handling status in My Cloud VOC.
For any further questions, feel free to contact us through the chatbot.
Chatbot