When you want to improve the security of a microservice-oriented application, you can configure authentication for other applications so that only the applications that match the authentication rule can call the microservice-oriented application.
The following example shows how to use service authentication in Dubbo.
Consumers 1, 2, and 3 and a provider belong to the same namespace. Consumers 1, 2, and 3 can call all the services and interfaces of the provider.
You can set an authentication method for all the services and interfaces of the provider. For example, set a blacklist for Consumer 1 to prevent it from calling the provider's services and interfaces, and set a whitelist for Consumers 2 and 3 to allow them to call the provider's services and interfaces.
You can also set an authentication method for specified services and interfaces of the provider. For example, set a blacklist for Consumer 2 to prevent it from calling the services and Interface 2 of the provider because they involve core business or data. Then, Consumer 2 can only call Interfaces 1 and 3 of the provider.
The following figure shows the call process with authentication rules configured.
Create a service authentication rule
- In the left-side navigation pane of Spring Cloud, click Service Authentication.
- On the Service Authentication page, click Create Rules.
- On the Create Rules page, set service authentication parameters, and click OK.
Service authentication rule parameters:
Parameter Description Namespaces The region and Namespaces where the service is located. Rule Name The name of the authentication rule. It can contain uppercase or lowercase letters, digits, underscores (_), and hyphens (-). It can be up to 64 characters in length. Callee Framework The framework used by the called application. Select Spring Cloud. Called Party The called application. Add All Interface RulesNotice You can add a common rule for all interfaces only once. Called Party
- Spring Cloud: The default value is All Paths, which cannot be changed.
- Dubbo: The default value is All Services /All Interfaces, which cannot be changed.
Authentication Mode The service authentication mode. Values: Whitelist (Allow Call) and Blacklist (Deny Call). Select an option as needed. Caller The application that requires authentication for calling the service. Click Add Caller to select multiple applications. Add Specified Interface RuleNotice The rules added to the specified interface are not appended. Instead, they overwrite the common rules (if any) for all interfaces. Callee Interface Callee Framework includes Spring Cloud and Dubbo. The setting of Callee Interface varies depending on the selected framework.
- Spring Cloud: the path to the called application.
- Dubbo: the service and interface of the called application.
Authentication Mode The service authentication mode. Values: Whitelist (Allow Call) and Blacklist (Deny Call). Select an option as needed. Caller The application that requires authentication for calling the service. Click Add Caller to select multiple applications. State Specifies whether to enable the rule.
- On (default value): the rule is enabled once created.
- Off: the rule is not enabled once created. To enable the rule, find it on the Service Authentication page and click Enable in the Operating column.
Verify the result
After the service authentication rule is configured and enabled, verify whether it takes effect as needed.