Executando um banco de dados de teste no disco RAM

2

É possível criar e iniciar um servidor Postgresql como um usuário não privilegiado com diretório de dados de propriedade do mesmo usuário? Eu quero executar testes e criar um banco de dados de teste para ele, os arquivos de dados estão localizados em um disco RAM.

$ mkdir -p /dev/shm/tests
$ pg_createcluster 9.3 tests -d /dev/shm/tests/pgsql/data
install: cannot change permissions of ‘/etc/postgresql/9.3/tests’: No such file or directory
Error: could not create configuration directory; you might need to run this program with root privileges

Se sudo for inevitável, existe uma maneira de inserir a senha do administrador apenas uma vez, para que as execuções de teste subsequentes não exijam isso? Quer dizer, eu gostaria de parar o servidor de teste e seu diretório de dados após os testes.

    
por warvariuc 25.11.2013 / 09:00

2 respostas

0

Ok, demorei um pouco para fazer isso funcionar, mas aqui está:

def run(command, action_descr, env=None):
    print '\n%s' % termcolor.colorize(action_descr, termcolor.c.YELLOW)
    print '$ %s' % termcolor.colorize(command, termcolor.c.YELLOW)
    try:
        output = subprocess.check_output(command, env=env, shell=True)
    except subprocess.CalledProcessError as exc:
        print termcolor.colorize('FAIL:\n%s' % exc.output, termcolor.c.RED, True)
        raise
    else:
        print termcolor.colorize('OK', termcolor.c.GREEN, True)
        return output


def create_test_db_template():
    """Create test template database.
    """
    PG_DIR = run('pg_config --bindir', 'Getting the location of Postgresql executables').strip()
    PG_CTL = os.path.join(PG_DIR, 'pg_ctl')

    test_db_directory = settings.get('tests', 'db_directory')

    env = os.environ.copy()
    env['PGDATA'] = test_db_directory
    env['PGPORT'] = settings.get_test_db_port()

    try:
        status = run('%s status' % PG_CTL, 'Checking previous test server status', env)
    except subprocess.CalledProcessError:
        pass
    else:
        print status
        run('%s stop' % PG_CTL, 'Stopping previous instance of test server', env)

    run('rm -rf %s' % test_db_directory, 'Deleting server data directory')
    run('mkdir -p %s' % test_db_directory, 'Creating server data directory')
    run('%s initdb -o "--auth-host=trust --nosync"' % PG_CTL,
        'Initializing test server and data directory', env)

    pg_log_path = os.path.join(test_db_directory, 'logfile')
    try:
        run('%s start -w --log %s' % (PG_CTL, pg_log_path), 'Starting test server', env)
    except subprocess.CalledProcessError:
        print termcolor.colorize(open(pg_log_path).read(), termcolor.c.RED)
        raise

    for db_name, db_queries in INIT_DB_SQL:
        for db_query in db_queries:
            run('psql %s -c "%s"' % (db_name, db_query), 'Creating template database', env)

    test_template_db_url = 'postgresql://127.0.0.1:%s/%s' % (env['PGPORT'], TEST_TEMPLATE_DB_NAME)
    postgres_db_url = 'postgresql://127.0.0.1:%s/postgres' % (env['PGPORT'])
    ...

Isso tem muito código adicional, mas você deve ter a idéia.

A única coisa a fazer manualmente é fazer:

sudo chmod 777 /var/run/postgresql

Esta solução está sem o disco RAM, mas a maior parte da solução para iniciar o servidor Postgresql no espaço do usuário está aqui.

Para executar tudo isso em um disco RAM, faça test_db_directory = 'dev/shm/pgdata/'

    
por 27.11.2013 / 13:41
1

pg_createcluster insistirá em colocar os arquivos de configuração no local privilegiado predefinido. Para contornar isso, basta chamar initdb diretamente:

/usr/lib/postgresql/9.3/bin/initdb /dev/shm/tests/pgsql/data

É claro que você também pode configurar sudo para não exigir uma senha, mas essa é realmente uma pergunta diferente com muitas respostas já disponíveis.

    
por 26.11.2013 / 22:19