Changing the Endpoint of a Deployed Proxy Service¶
The below sections describe how you can change the endpoint reference of a deployed proxy service without changing its own configuration. For example, in this scenario, you have two endpoints to manage two environments (i.e., Dev and QA). The endpoint URLs for the services hosted in the Dev and QA environments respectively are as follows:
-
Dev environment:
http://localhost:8290/services/echo
-
QA environment:
http://localhost:8291/services/echo
Creating the Endpoints¶
You need to create two Endpoint artifacts to represent the Dev and QA environments respectively. Follow the steps given below.
- Create two projects as given below.
Project Name Description HelloWorldDevResources The project will store the Endpoint artifact for the Dev environment. HelloWorldQAResources The project will store the Endpoint artifact for the QA environment. -
Create two Endpoint artifacts in two projects with the following configurations:
-
HelloWorldDevResources
projectEndpoint Parameter Value Endpoint Name HelloWorldEP
Endpoint Type Address Endpoint Address URL http://localhost:8290/services/echo
-
HelloWorldQAResources
projectEndpoint Parameter Value Endpoint Name HelloWorldEP
Endpoint Type Address Endpoint Address URL http://localhost:8291/services/echo
-
Creating the Proxy Service¶
- Create a project named HelloWorldServices.
-
Create a proxy service in the HelloWorldServices project with the following configurations:
Parameter Value Proxy Service Name HelloWorldProxy
Proxy Service Type Select Pass Through Proxy Endpoint Select HelloWorldEP (You need to select Predefined Endpoint from the endpoint options listed.)
The project setup is now complete.
Creating the composite application projects¶
Create two composite application projects to package the QA artifacts and Dev artifacts separately. The proxy service and the Dev endpoint must go in its own CApp, and the proxy service and the QA endpoint should be in another CApp as shown below.
See the instructions on packaging artifacts into CApps.
Environment | CApp Name | Artifacts Included |
---|---|---|
Dev | HelloWorldDevCApp |
HelloWorldServices project and the
HelloWorldDevResources project.
|
QA | HelloWorldQACApp |
HelloWorldServices project and the
HelloWorldQAResources project.
|
Your CApp projects are now ready to be deployed to the Micro Integrator.
Deploying the Dev composite application¶
If you have an instance of WSO2 Micro Integrator setup as your Dev environment, deploy the HelloWorldDevCApp CApp in the server.
Testing the Dev environment¶
Use the following request body when invoking the service:
<body>
<p:echoInt xmlns:p="http://echo.services.core.carbon.wso2.org">
<!--0 to 1 occurrence-->
<in>50</in>
</p:echoInt>
</body>
Changing the endpoint reference¶
Follow the steps below to change the endpoint reference of the HelloWorldProxy you deployed, to point it to the QA environment, without changing its configuration.
-
Set a port offset by changing the following configuration in the
MI_HOME/conf/deployment.toml
file.2. Undeploy the HelloWorldDevCApp, deploy the HelloWorldQACApp and re-start the Micro Integrator.offset=2
Testing the QA environment¶
Use the following request body when invoking the service:
<body>
<p:echoInt xmlns:p="http://echo.services.core.carbon.wso2.org">
<!--0 to 1 occurrence-->
<in>100</in>
</p:echoInt>
</body>
Changing an endpoint reference¶
Once the endpoint has been created, you can update it using any one of the options listed below. The options below describe how you can update the endpoint value for QA environment.
Option 1: Using WSO2 MI VS Code Extension¶
-
Open the
HelloWorldEP
endpoint form from the WSO2 MI VS Code extension Project Overview page and update the URL with the QA URL. -
Click on the Build button on the top right corner of the Project Overview page to build the Carbon Application.
-
The resulting CAR file will be stored in the
<Workspace>/HelloWorldQAResources/target
folder and it can be deployed in the MI server.
Option 2: From Command Line¶
- Open a Terminal window and navigate to
<WORKSPACE>/HelloWorldQAResources/src/main/wso2mi/artifacts/endpoints/HelloWorldEP.xml
file. -
Edit the HelloWorldEP.xml (e.g. using gedit or vi) under HelloWorldResources/QA and replace the URL with the QA one.
... <address uri="http://192.168.1.110:9773/services/HelloService/"/> ...
-
Navigate to
<Workspace>/HelloWorldQAResources
and build the project using the following command:mvn clean install
-
The resulting CAR file will be stored in the
<Workspace>/HelloWorldQAResources/target
folder and it can be deployed in the MI server.
Note
- To build the projects using the above commands, you need an active network connection.
- Creating a Maven Multi Module project that contains the above projects, allows you to projects in one go by simply building the parent Maven Multi Module project.
Option 3: Using a Script¶
Alternatively you can have a CAR file with dummy values for the endpoint URLs and use a customized shell script or batch script. The script created would need to do the following:
- Extract the CAR file.
- Edit the URL values.
- Re-create the CAR file with new values.
The resulting CAR file can be deployed in the QA MI server.