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

Improvements for MTR rebootstrap introduced in MDEV-12042

    XMLWordPrintable

Details

    • Bug
    • Status: Closed (View Workflow)
    • Major
    • Resolution: Fixed
    • 10.0, 10.1(EOL), 10.2(EOL)
    • 10.0.33, 10.1.27, 10.2.9
    • Tests
    • None

    Description

      Change in MTR made in scope of MDEV-12042 allow it to rebootstrap the server between consequent tests, if a test's options are suspected to be not compatible with the original bootstrap. The list of such options is hardcoded:

           if ( $extra_opts and
                 "@$extra_opts" =~ /--innodb[-_](?:page[-_]size|checksum[-_]algorithm|undo[-_]tablespaces|log[-_]group[-_]home[-_]dir|data[-_]home[-_]dir)/ )
            {
              mysql_install_db($mysqld, undef, $extra_opts);
            }
      

      There are some problems to fix and things to improve.

      1. Re-bootstrap with inconsistent set of options

      The above logic does not work well enough when InnoDB options depend on other server settings. For example, if we run

      $ perl ./mtr encryption.innodb_encryption --mysqld=--innodb-undo-tablespaces=0 --mem 
      

      we'll get

      encryption.innodb_encryption 'innodb_plugin' [ fail ]  Found warnings/errors in server log file!
              Test ended at 2017-08-18 19:04:19
      line
      2017-08-18 19:03:42 140593044430976 [Warning] InnoDB: New log files created, LSN=45887
      2017-08-18 19:03:42 140593044430976 [Warning] InnoDB: Creating foreign key constraint system tables.
      ^ Found warnings in /data/src/bb-10.1-elenst/mysql-test/var/log/mysqld.1.err
      ok
      

      This is because rebootstrap here doesn't actually work. It attempts to start with innodb options which require encryption, but without the encryption plugin itself, because it only chooses InnoDB options from $extra_opts, while plugin-load-add is ignored; so InnoDB doesn't start at all, and hence the tables and log files don't get created upon bootstrap.
      From the bootstrap log:

      2017-08-18 19:12:20 139995187245184 [ERROR] InnoDB: cannot enable encryption, encryption plugin is not available
      2017-08-18 19:12:20 139995187245184 [ERROR] Plugin 'InnoDB' init function returned error.
      2017-08-18 19:12:20 139995187245184 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
      

      2. Re-creating bootstrap.sql upon re-bootstrap

      Every time re-bootstrap is issued, it re-creates bootstrap.sql file from scratch. It shouldn't take that much resources, but it is unnecessary; besides, we are having troubles on Windows, where tests sometimes fail upon re-bootsrap apparently because the bootstrap.sql file is locked when they want to re-create it. While we don't know root cause of the problem, it might well go away if we just stop re-creating it when it already exists. One catch is that currently it's located in var/tmp, which is removed between the tests; but we can store it in var/log instead, it might even be beneficial to keep it after test run when we want to analyze some obscure bootstrap problems.

      3. Bootstrap log on Windows

      Not directly related to MDEV-12042, but rather to investigating problems upon re-bootstrap – Wlad requested adding --console to bootstrap, to get more useful log.

      Attachments

        Activity

          People

            elenst Elena Stepanova
            elenst Elena Stepanova
            Votes:
            0 Vote for this issue
            Watchers:
            2 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.