Authority Management
user_identity
In a permission system, a user is identified as a User Identity. User ID consists of two parts: username and userhost. Username is a user name, which is composed of English upper and lower case. Userhost represents the IP from which the user link comes. User_identity is presented as username@’userhost’, representing the username from userhost.
Another expression of user_identity is username@[‘domain’], where domain is the domain name, which can be resolved into a set of IPS by DNS BNS (Baidu Name Service). The final expression is a set of username@’userhost’, so we use username@’userhost’to represent it.
Privilege
The objects of permissions are nodes, databases or tables. Different permissions represent different operating permissions.
Role
Doris can create custom named roles. Roles can be seen as a set of permissions. When a newly created user can be assigned a role, the role’s permissions are automatically granted. Subsequent changes in the role’s permissions will also be reflected in all user permissions that belong to the role.
user_property
User attributes are directly attached to a user, not to a user identity. That is, both cmy@’192.%’and cmy@[‘domain’] have the same set of user attributes, which belong to user cmy, not cmy@’192.%’ or cmy@[‘domain’].
User attributes include, but are not limited to, the maximum number of user connections, import cluster configuration, and so on.
Supported operations
- Create users: CREATE USER
- Delete users: DROP USER
- Authorization: GRANT
- Withdrawal: REVOKE
- Create role: CREATE ROLE
- Delete Roles: DROP ROLE
- View current user privileges: SHOW GRANTS
- View all user privilegesSHOW ALL GRANTS;
- View the created roles: SHOW ROLES
For detailed help with the above commands, you can use help + command to get help after connecting Doris through the MySQL client. For example .
Doris currently supports the following permissions
Node_priv
Nodes change permissions. Including FE, BE, BROKER node addition, deletion, offline operations. Currently, this permission can only be granted to Root users.
Grant_priv
Permissions change permissions. Allow the execution of operations including authorization, revocation, add/delete/change user/role, etc.
Select_priv
Read-only access to databases and tables.
Load_priv
Write permissions to databases and tables. Including Load, Insert, Delete and so on.
Alter_priv
Change permissions on databases and tables. It includes renaming libraries/tables, adding/deleting/changing columns, and adding/deleting partitions.
Create_priv
Drop_priv
Delete permissions for databases, tables, and views.
Permission hierarchy
At the same time, according to the scope of application of permissions, we divide them into three levels:
- GLOBAL LEVEL: Global permissions. That is, permissions on
*.*
granted by GRANT statements. The granted permissions apply to any table in any database. - DATABASE LEVEL: Database-level permissions. That is, permissions on
db.*
granted by GRANT statements. The granted permissions apply to any table in the specified database. - TABLE LEVEL: Table-level permissions. That is, permissions on
db.tbl
granted by GRANT statements. The permissions granted apply to the specified tables in the specified database.
ADMIN_PRIV and GRANT_PRIV have the authority of “grant authority” at the same time, which is more special. The operations related to these two privileges are described here one by one.
CREATE USER
- Users with ADMIN or GRANT privileges at any level can create new users.
DROP USER
- Only ADMIN privileges can delete users.
CREATE/DROP ROLE
- Only ADMIN privileges can create roles.
GRANT /REVOKE
- Users with ADMIN or GLOBAL GRANT privileges can grant or revoke the privileges of any user.
- Users with GRANT privileges at the DATABASE level can grant or revoke the privileges of any user on the specified database.
- Users with GRANT privileges at TABLE level can grant or revoke the privileges of any user on the specified tables in the specified database.
Some explanations
When Doris initializes, the following users and roles are automatically created:
Operator role: This role has Node_priv and Admin_priv, i.e. all permissions for Doris. In a subsequent upgrade version, we may restrict the role’s permissions to Node_priv, which is to grant only node change permissions. To meet some cloud deployment requirements.
admin role: This role has Admin_priv, which is all permissions except for node changes.
root@’%’: root user, which allows login from any node, with the role of operator.
admin@’%’: admin user, allowing login from any node, role admin.
It is not supported to delete or change the permissions of default created roles or users.
The user of the operator role has one and only one user. Users of admin roles can create multiple.
Operational instructions for possible conflicts
Conflict between domain name and ip:
Assume that the following users are created:
CREATE USER cmy@[‘domain’];
And authorize:
GRANT SELECT_PRIV ON *.* TO cmy@[‘domain’]
The domain is resolved into two ips: IP1 and IP2
GRANT ALTER_PRIV ON *.* TO cmy@’ip1’;
The permissions of CMY @’ip1’will be changed to SELECT_PRIV, ALTER_PRIV. And when we change the permissions of cmy@[‘domain’] again, cmy@’ip1’ will not follow.
duplicate IP conflicts:
Assume that the following users are created:
CREATE USER cmy@’%’ IDENTIFIED BY “12345”;
CREATE USER cmy@’192.%’ IDENTIFIED BY “abcde”;
In priority,’192.%’takes precedence over’%’, so when user CMY tries to login Doris with password ‘12345’ from 192.168.1.1, the machine will be rejected.
Forget passwords
If you forget your password and cannot log in to Doris, you can log in to Doris without a password using the following command on the machine where the Doris FE node is located:
mysql-client -h 127.0.0.1 -P query_port -uroot
After login, the password can be reset through the SET PASSWORD command.
No user can reset the password of the root user except the root user himself.
ADMIN_PRIV permissions can only be granted or revoked at the GLOBAL level.
Having GRANT_PRIV at GLOBAL level is actually equivalent to having ADMIN_PRIV, because GRANT_PRIV at this level has the right to grant arbitrary permissions, please use it carefully.
current_user()
anduser()
Users can view
current_user
and respectively bySELECT current_user();
andSELECT user();
. Wherecurrent_user
indicates which identity the current user is passing through the authentication system, anduser
is the user’s current actualuser_identity
.
For example, suppose the user user1@'192.%'
is created, and then a user user1 from 192.168.10.1 is logged into the system. At this time, current_user
is user1@'192.%'
, and is user1@'192.168.10.1'
.
Here are some usage scenarios of Doris privilege system.
Scene 1
The users of Doris cluster are divided into Admin, RD and Client. Administrators have all the rights of the whole cluster, mainly responsible for cluster building, node management and so on. The development engineer is responsible for business modeling, including database building, data import and modification. Users access different databases and tables to get data.
In this scenario, ADMIN or GRANT privileges can be granted to administrators. Give RD CREATE, DROP, ALTER, LOAD, SELECT permissions to any or specified database tables. Give Client SELECT permission to any or specified database table. At the same time, it can also simplify the authorization of multiple users by creating different roles.
Scene 2
There are multiple services in a cluster, and each business may use one or more data. Each business needs to manage its own users. In this scenario. Administrator users can create a user with GRANT privileges at the DATABASE level for each database. The user can only authorize the specified database for the user.