此内容没有您所选择的语言版本。
Chapter 9. Users and Roles
The broker supports a flexible role-based security model for applying security to queues based on their respective addresses. It is important to understand that queues are bound to addresses either one-to-one (for point-to-point style messaging) or many-to-one (for publish-subscribe style messaging). When a message is sent to an address the server looks up the set of queues that are bound to that address and routes the message to that set of queues.
			In the default configuration (using PropertiesLoginModule), users and their assigned roles are defined in three configuration files:
		
- 
					login.config
- 
					artemis-users.properties
- 
					artemis-roles.properties
Each of these files is discussed in more detail in the following sections.
The command-line interface allows users and roles to be added to these files via an interactive process.
				The artemis-users.properties file can contain hashed passwords for security.
			
9.1. Enabling Guest Access
A user who does not have login credentials, or whose credentials fail validation, can be granted limited access to the broker using a guest account.
				A broker instance can be created with guest access enabled using the command-line switch; --allow-anonymous (the converse of which is --require-login).
			
				The guest account is configured in the login.config file.
			
Procedure
- 
						In the login.configfile, define a name and role for the guest account as follows:
activemq {
  org.apache.activemq.artemis.spi.core.security.jaas.GuestLoginModule required
      org.apache.activemq.jaas.guest.user="guest" 
      org.apache.activemq.jaas.guest.role="guest"; 
};
activemq {
  org.apache.activemq.artemis.spi.core.security.jaas.GuestLoginModule required
      org.apache.activemq.jaas.guest.user="guest" 
      org.apache.activemq.jaas.guest.role="guest"; 
};
				The guest login module allows users without credentials (and, depending on how it is configured, possibly also users with invalid credentials) to access the broker. It is implemented by org.apache.activemq.artemis.spi.core.security.jaas.GuestLoginModule.
			
It is common for the guest login module to be used in conjunction with another login module, such as a properties login module. Read more about that use-case in the Section 10.2.4, “Using Multiple Login Modules” section.
9.2. Adding Users
When basic username and password validation is required, use the Properties login module to define it. This login module checks the user’s credentials against a set of local property files.
				Users and their corresponding passwords are listed in the BROKER_INSTANCE_DIR/etc/artemis-users.properties file. The available roles and the users who are assigned those roles are defined in the BROKER_INSTANCE_DIR/etc/artemis-roles.properties file.
			
				Both of these files are referenced in the BROKER_INSTANCE_DIR/etc/login.config file.
			
				See the documentation from your Java vendor for more information on JAAS. For example, Oracle has a tutorial on configuring login.config.
			
Example 9.1. login.config
activemq { 
    org.apache.activemq.artemis.spi.core.security.jaas.PropertiesLoginModule required  
        org.apache.activemq.jaas.properties.user="artemis-users.properties"; 
        org.apache.activemq.jaas.properties.role="artemis-roles.properties";
};
activemq { 
    org.apache.activemq.artemis.spi.core.security.jaas.PropertiesLoginModule required  
        org.apache.activemq.jaas.properties.user="artemis-users.properties"; 
        org.apache.activemq.jaas.properties.role="artemis-roles.properties";
};- 1
- An alias for a configuration. In this section the alias used isactivemq. Substitute another in your environment.
- 2
- The implementation class (org.apache.activemq.artemis.spi.core.security.jaas.PropertiesLoginModule).
- 3
- A flag which indicates whether the success of theLoginModule is `required,requisite,sufficient, oroptional.
- 4
- A list of configuration options specific to the login module implementation.
Below is an explanation for each of the success states listed in the previous example:
- Required
- The LoginModule is required to succeed and authentication continues to proceed down the LoginModule list regardless of success or failure.
- Requisite
- The LoginModule is required to succeed. A failure immediately returns control to the application and authentication does not proceed down the LoginModule list.
- Sufficient
- 
							The LoginModule is not required to succeed. If it is successful, control returns to the application and authentication does not proceed further. If it fails, the authentication attempt proceeds down the LoginModulelist.
- Optional
- 
							The LoginModule is not required to succeed. Authentication continues down the LoginModuleslist regardless of success or failure.
More information on these flags and the authentication process is available in the Oracle documentation.
Example 9.2. artemis-users.properties
Example 9.3. artemis-roles.properties
					If necessary, add your security domain alias (in this instance, activemq) to the bootstrap.xml file as shown below:
				
<jaas-security domain="activemq"/>
<jaas-security domain="activemq"/>9.3. Setting Permissions
				Permissions are defined against the queues based on their address via the <security-setting> element in broker.xml. Multiple instances of <security-setting> can be defined in <security-settings>. An exact match on the address can be used or a wildcard match can be used using the wildcard characters # and *.
			
Different permissions can be given to the set of queues which match the address. Those permissions are:
| To allow users to… | Use this parameter… | 
|---|---|
| Create addresses | 
								 | 
| Delete addresses | 
								 | 
| Create a durable queue under matching addresses | 
								 | 
| Delete a durable queue under matching addresses | 
								 | 
| Create a non-durable queue under matching addresses | 
								 | 
| Delete a non-durable queue under matching addresses | 
								 | 
| Send a message to matching addresses | 
								 | 
| Consume a message from a queue bound to matching addresses | 
								 | 
| Invoke management operations by sending management messages to the management address | 
								 | 
| Browse a queue bound to the matching address | 
								 | 
For each permission, a list of roles who are granted that permission is specified. If the user has any of those roles, they are granted that permission for that set of addresses.
To define sending permissions for a single address, a configuration similar to the example shown below is used:
<security-settings>
    <security-setting match="queue1"> 
        <permission type="send" roles="producer"/> 
    </security-setting>
</security-settings>
<security-settings>
    <security-setting match="queue1"> 
        <permission type="send" roles="producer"/> 
    </security-setting>
</security-settings>In the above example, members of the producer role have send permissions on queue1.
To define consuming permissions for a single address, a configuration similar to the example shown below is used:
<security-settings>
    <security-setting match="queue1"> 
        <permission type="consume" roles="consumer"/> 
    </security-setting>
</security-settings>
<security-settings>
    <security-setting match="queue1"> 
        <permission type="consume" roles="consumer"/> 
    </security-setting>
</security-settings>In the above example, members of the consumer role have consume permissions on queue1.
9.3.3. Configuring Complete Access on All Addresses
To allow complete access to addresses and and queues, a configuration similar to the example shown below is used.
- 1
- A wildcard setting to apply to all queues.
					In the above configuration, all permissions are granted to members of the guest role on all queues. This can be be useful in a development scenario where anonymous authentication was configured to assign the guest role to every user.
				
For information about more complex use cases see Configuring Multiple Permissions for Addresses.
9.4. Setting Role Based Access Control
				Role-based access control (RBAC) is used to restrict access to the attributes and methods of MBeans. RBAC enables administrators to grant the correct level of access to all users like web console, management interface, core messages, and so on based on their role. RBAC is configured using the authorization element in the BROKER_INSTANCE_DIR/etc/management.xml configuration file. Within the authorization element, you can configure Whitelist, default-access, and role-access sub-elements.
			
Prerequisites
You must first set up roles and add users to configure RBAC.
					A whitelist is a set of pre-approved domains or MBeans that do not require user authentication. You can provide a whitelist of domains or list of MBeans or both that must bypass the authentication. For example, you can use whitelist element for any MBeans that are needed by the AMQ Console to run.
				
Procedure
- 
							Open the broker BROKER_INSTANCE_DIR/etc/management.xmlconfiguration file.
- Search for the - whitelistelement and edit the configuration:- <whitelist> <entry domain="hawtio"/> </whitelist> - <whitelist> <entry domain="hawtio"/>- 1 - </whitelist>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- MBean of this domain will bypass the authentication.
 - In this example, any MBean with the domain - hawtiowill be allowed access without authentication. You can also use wildcard entries like- <entry domain="hawtio" key="type=*"/>for the MBean properties to match.
- Start or restart the broker by entering the following command: - 
									On Linux: BROKER_INSTANCE_DIR/bin/artemis run
- 
									On Windows: BROKER_INSTANCE_DIR\bin\artemis-service.exe start
 
- 
									On Linux: 
9.4.2. Configuring Authentication Based on Roles
					The role-access method defines how roles are mapped to particular MBeans and their attributes and methods.
				
Procedure
- 
							Open the BROKER_INSTANCE_DIR/etc/management.xmlconfiguration file.
- Search for the - role-accesselement and edit the configuration:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Important- === You must ensure that the order of the individual lines in the configuration is as per the template. Any change in the line indentation leads to changes in the semantics of the assigned privileges. For example, if you move the line - <access method="*" roles="amq,guest"/>inside the- <role-access>tag from last position to the first, it changes the semantics of applied privileges. If used as the first line, it means grant access to everything to these roles with the exception of following specific cases. If used as the last line, it means grant access to everything to these roles (default). ===- Here, the specific tasks like - list*,- get*,- set*,- isand- *are specified using the access method. The invoked method is matched against the methods listed in the configuration. The user is assigned the roles given for the best matching method. For example, if you try the invoke a method called- listMessageson an MBean with the- org.apache.activemq.artemisdomain, then it would match the access with the method of- list. You can also explicitly configure this by using the full method name like the following:- <access method="listMessages" roles="view,update,amq"/>.
- Start or restart the broker by entering the following command: - 
									On Linux: BROKER_INSTANCE_DIR/bin/artemis run
- 
									On Windows: BROKER_INSTANCE_DIR\bin\artemis-service.exe start
 
- 
									On Linux: 
					You can also match specific MBeans within a domain by adding a key attribute that matches an MBean property. For example,
				
					Access to MBean attributes are converted to method calls, so these are controlled using the list*, set*, get*, and is* syntax. The * (wildcard) syntax is used as a catch-all for every other method that is not listed in the configuration.
				
						The default-access element is mainly the catch-all for every method call that is not handled using the role-access configuration. The default-access and role-access have the same match element semantics.