Uploaded image for project: 'MariaDB Server'
  1. MariaDB Server
  2. MDEV-12684

Show what config file a sysvar got a value from

Details

    Description

      Extend INFORMATION_SCHEMA.SYSTEM_VARIABLES to show what .cnf file the value was read from. Note that included files (with !include and !includedir) should be shown, not just the master /etc/my.cnf.

      Possible implementation, load_defaults() adds (may be on request only) special options in the argv list, like --file-name /my/cnf/path. And handle_options() uses that (comparing pointers, just like with --separator--).

      This could go into GLOBAL_VALUE_ORIGIN column or into a new column, say, GLOBAL_VALUE_ORIGIN_INFO
      which would have a file name for CONFIG, and, say, username for SQL.

      Original description:

      It's really difficult to check that MySQL/MariaDB is using my.cnf or not. Also we can't check that what are the default values of variables through mysql client. It would be really helpful if we can do like

      1. Add 3rd column like "last updated by" (read cnf, set global, set session, default)
      or
      2. Make separate command like SHOW DEFAULT VARIABLES
      or
      3. Adding columns to information_schema.global_variables to check details

      Attachments

        Activity

          I just had a look at the MySQL 8.0 implementation in P_S.VARIABLES_INFO,
          and it seems to have almost everything I ever wished for:

          • shows by what mechanism a variable has been set
          • in case of option files: which file it was actually read from (resolving !include and !includedir)
          • in case of SQL level SET: when it was last changed, and by whom

          The only thing missing from my wish list there would be an additional
          VARIABLES_INFO_HISTORY table, to allow for tracking past changes ...

          hholzgra Hartmut Holzgraefe added a comment - I just had a look at the MySQL 8.0 implementation in P_S.VARIABLES_INFO, and it seems to have almost everything I ever wished for: shows by what mechanism a variable has been set in case of option files: which file it was actually read from (resolving !include and !includedir) in case of SQL level SET: when it was last changed, and by whom The only thing missing from my wish list there would be an additional VARIABLES_INFO_HISTORY table, to allow for tracking past changes ...
          ralf.gebhardt Ralf Gebhardt added a comment - - edited

          Hi serg in one comment you wrote that this request is complex but the estimate is 2 days. Is 2 days a good estimate? The task is currently for 10.5, but not on our roadmap. It could be a good one if in the backlog for 10.5 if the 2 days are correct.

          ralf.gebhardt Ralf Gebhardt added a comment - - edited Hi serg in one comment you wrote that this request is complex but the estimate is 2 days. Is 2 days a good estimate? The task is currently for 10.5, but not on our roadmap. It could be a good one if in the backlog for 10.5 if the 2 days are correct.

          I think 2 days is about right

          serg Sergei Golubchik added a comment - I think 2 days is about right
          serg Sergei Golubchik added a comment - bar , please see https://github.com/MariaDB/server/compare/10.5...bb-10.5-serg

          Ok to push.

          A proposal for tests:

          Would be nice to run this query:

          select * from information_schema.system_variables
          where global_value_path is not null;
          

          both for super-user and for non-privileged user.

          bar Alexander Barkov added a comment - Ok to push. A proposal for tests: Would be nice to run this query: select * from information_schema.system_variables where global_value_path is not null ; both for super-user and for non-privileged user.

          People

            serg Sergei Golubchik
            niljoshi Nilnandan Joshi
            Votes:
            1 Vote for this issue
            Watchers:
            9 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved:

              Git Integration

                Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.