Skip to content

unix196/saltstack_clickhouse_users

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 

Repository files navigation

Primitive module for configure users in Clickhouse database using sql mode. Until recently users in Clickhouse were configured via xml file, which doesn't allow fine configuring permissions, like in mysql or postgresql. In fresh versions Clickhouse allows you to configure users through the familiar sql mode.

/etc/salt/master.d/f_defaults.conf:
...
file_roots:
  base:
  - /srv/salt/base
  ...

master# ls -1 /srv/salt/base/_modules/
clickhouse.py

salt-call saltutil.sync_modules - copy self-written module from salt master to salt minion. default minion cachedir - /var/cache/salt/minion (https://docs.saltproject.io/en/3000/ref/configuration/minion.html#cachedir) On minion clickhouse module will be located here (debian-based OS):

minion# ls -1 /var/cache/salt/minion/extmods/modules/
clickhouse.py
  • How to understand what rights current users needs (thank's our programmers :) ):
select
       initial_user,
       user,
       arrayFilter(x -> notEmpty(x), groupUniqArray(query_kind)) op,
       arrayDistinct(arrayFlatten(groupUniqArray(databases))) db
from system.query_log
where notEmpty(user)
GROUP BY initial_user, user;

This query can provide information for migration from xml to sql mode in existing Clickhouse installation.

initial_user user op
user1 user1 ['SELECT','INSERT']
user2 user2 ['SELECT']
user3 user3 ['SELECT','SHOW','INSERT']
user4 user4 ['SELECT','INSERT']
user5 user5 ['INSERT']

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published