Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
slapos
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Rafael Monnerat
slapos
Commits
d51a7948
Commit
d51a7948
authored
Dec 15, 2018
by
Julien Muchembled
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
NEO: add support for SQLite backend
See sqlite-mixin.cfg to skip the building of MariaDB.
parent
d1174fd4
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
64 additions
and
24 deletions
+64
-24
slapos/recipe/mkdirectory.py
slapos/recipe/mkdirectory.py
+3
-0
software/neoppod/instance-common.cfg.in
software/neoppod/instance-common.cfg.in
+4
-2
software/neoppod/instance-neo-input-schema.json
software/neoppod/instance-neo-input-schema.json
+5
-0
software/neoppod/instance-neo.cfg.in
software/neoppod/instance-neo.cfg.in
+29
-12
software/neoppod/instance.cfg.in
software/neoppod/instance.cfg.in
+4
-2
software/neoppod/software-common.cfg
software/neoppod/software-common.cfg
+10
-7
software/neoppod/software.cfg
software/neoppod/software.cfg
+2
-1
software/neoppod/sqlite-mixin.cfg
software/neoppod/sqlite-mixin.cfg
+7
-0
No files found.
slapos/recipe/mkdirectory.py
View file @
d51a7948
...
@@ -39,4 +39,7 @@ class Recipe(GenericBaseRecipe):
...
@@ -39,4 +39,7 @@ class Recipe(GenericBaseRecipe):
for
path
in
sorted
(
self
.
directory
.
itervalues
()):
for
path
in
sorted
(
self
.
directory
.
itervalues
()):
if
path
and
not
os
.
path
.
isdir
(
path
):
if
path
and
not
os
.
path
.
isdir
(
path
):
os
.
makedirs
(
path
,
self
.
mode
)
os
.
makedirs
(
path
,
self
.
mode
)
# WARNING: This recipe is currently used to create directories that will
# contain user data (e.g. NEO db). Such directories must never
# be purged by the uninstallation of a recipe.
return
[]
return
[]
software/neoppod/instance-common.cfg.in
View file @
d51a7948
...
@@ -33,11 +33,13 @@ template = {{ neo_admin }}
...
@@ -33,11 +33,13 @@ template = {{ neo_admin }}
<= jinja2-template-base
<= jinja2-template-base
template = {{ neo_master }}
template = {{ neo_master }}
[neo
-storage-mysql
]
[neo]
<= jinja2-template-base
<= jinja2-template-base
template = {{ neo
_storage_mysql
}}
template = {{ neo }}
extra-context =
extra-context =
key master_cfg neo-master:rendered
key master_cfg neo-master:rendered
key admin_cfg neo-admin:rendered
key admin_cfg neo-admin:rendered
{%- if mariadb_location is defined %}
raw mariadb_location {{ mariadb_location }}
raw mariadb_location {{ mariadb_location }}
raw template_neo_my_cnf {{ template_neo_my_cnf }}
raw template_neo_my_cnf {{ template_neo_my_cnf }}
{%- endif %}
software/neoppod/instance-neo-input-schema.json
View file @
d51a7948
...
@@ -84,6 +84,11 @@
...
@@ -84,6 +84,11 @@
"default"
:
false
,
"default"
:
false
,
"type"
:
"boolean"
"type"
:
"boolean"
},
},
"storage-type"
:
{
"description"
:
"Storage type. Defaults to MySQL if available, else SQLite."
,
"enum"
:
[
"MySQL"
,
"SQLite"
],
"type"
:
"string"
},
"mysql"
:
{
"mysql"
:
{
"description"
:
"Dictionary containing parameters for MySQL."
,
"description"
:
"Dictionary containing parameters for MySQL."
,
"default"
:
{},
"default"
:
{},
...
...
software/neoppod/instance-neo
-storage-mysql
.cfg.in
→
software/neoppod/instance-neo.cfg.in
View file @
d51a7948
...
@@ -2,6 +2,11 @@
...
@@ -2,6 +2,11 @@
{% set part_list = [] -%}
{% set part_list = [] -%}
{% set init_list = [] -%}
{% set init_list = [] -%}
{% set storage_type = slapparameter_dict.get('storage-type') or (
'MySQL' if mariadb_location is defined else 'SQLite') -%}
{% set mysql = storage_type == 'MySQL' -%}
{% if mysql -%}
[mysqld]
[mysqld]
recipe = slapos.cookbook:generic.mysql.wrap_mysqld
recipe = slapos.cookbook:generic.mysql.wrap_mysqld
output = ${directory:etc_run}/mariadb
output = ${directory:etc_run}/mariadb
...
@@ -34,6 +39,8 @@ command-line = ${mysqld:mysql-base-directory}/bin/${:command} --defaults-file=${
...
@@ -34,6 +39,8 @@ command-line = ${mysqld:mysql-base-directory}/bin/${:command} --defaults-file=${
wrapper-path = ${directory:bin}/${:command}
wrapper-path = ${directory:bin}/${:command}
command = mysql
command = mysql
{% endif -%}
[{{ section('binary-neolog') }}]
[{{ section('binary-neolog') }}]
recipe = slapos.cookbook:symbolic.link
recipe = slapos.cookbook:symbolic.link
target-directory = ${directory:bin}
target-directory = ${directory:bin}
...
@@ -95,7 +102,7 @@ ip = ${publish:ip}
...
@@ -95,7 +102,7 @@ ip = ${publish:ip}
ssl = {{ dumps(bool(slapparameter_dict['ssl'])) }}
ssl = {{ dumps(bool(slapparameter_dict['ssl'])) }}
cluster = {{ dumps(slapparameter_dict['cluster']) }}
cluster = {{ dumps(slapparameter_dict['cluster']) }}
masters = ${publish:masters}
masters = ${publish:masters}
database-adapter =
MySQL
database-adapter =
{{ storage_type }}
wait-database = -1
wait-database = -1
engine = {{ slapparameter_dict.get('engine', '') }}
engine = {{ slapparameter_dict.get('engine', '') }}
dedup = {{ dumps(bool(slapparameter_dict.get('data-deduplication'))) }}
dedup = {{ dumps(bool(slapparameter_dict.get('data-deduplication'))) }}
...
@@ -107,8 +114,15 @@ disable-drop-partitions = {{ dumps(bool(slapparameter_dict.get('disable-drop-par
...
@@ -107,8 +114,15 @@ disable-drop-partitions = {{ dumps(bool(slapparameter_dict.get('disable-drop-par
< = neo-storage
< = neo-storage
wrapper = ${directory:etc_run}/{{ 'neostorage-' ~ i }}
wrapper = ${directory:etc_run}/{{ 'neostorage-' ~ i }}
logfile = ${directory:log}/{{ 'neostorage-' ~ i }}.log
logfile = ${directory:log}/{{ 'neostorage-' ~ i }}.log
{% do init_list.append('CREATE DATABASE IF NOT EXISTS neo' ~ i ~ ';') -%}
{%- if mysql %}
{%- do init_list.append('CREATE DATABASE IF NOT EXISTS neo' ~ i ~ ';') %}
database-parameters = root@neo{{ i }}${my-cnf-parameters:socket}
database-parameters = root@neo{{ i }}${my-cnf-parameters:socket}
{%- else %}
database-parameters = ${directory:db-{{i}}}/db.sqlite
[directory]
db-{{i}} = ${buildout:directory}/srv/{{ storage_id }}
{%- endif %}
[{{ section('logrotate-storage-' ~ i) }}]
[{{ section('logrotate-storage-' ~ i) }}]
< = logrotate-entry-base
< = logrotate-entry-base
...
@@ -117,12 +131,6 @@ log = {{ '${' + storage_id + ':logfile}' }}
...
@@ -117,12 +131,6 @@ log = {{ '${' + storage_id + ':logfile}' }}
post = {{ bin_directory }}/slapos-kill -s RTMIN+1 -- {{ bin_directory }}/neostorage -l ${:log}
post = {{ bin_directory }}/slapos-kill -s RTMIN+1 -- {{ bin_directory }}/neostorage -l ${:log}
{% endfor -%}
{% endfor -%}
[init-script]
recipe = slapos.recipe.template:jinja2
# XXX: is there a better location ?
rendered = ${directory:etc}/mariadb_initial_setup.sql
template = inline:
{{ init_list | join('\n\t') }}
[directory]
[directory]
recipe = slapos.cookbook:mkdirectory
recipe = slapos.cookbook:mkdirectory
...
@@ -132,11 +140,19 @@ etc = ${buildout:directory}/etc
...
@@ -132,11 +140,19 @@ etc = ${buildout:directory}/etc
var = ${buildout:directory}/var
var = ${buildout:directory}/var
etc_run = ${:etc}/run
etc_run = ${:etc}/run
var_run = ${:var}/run
var_run = ${:var}/run
srv_mariadb = ${buildout:directory}/srv/mariadb
log = ${buildout:directory}/var/log
log = ${buildout:directory}/var/log
tmp = ${buildout:directory}/tmp
tmp = ${buildout:directory}/tmp
{% if mysql -%}
srv_mariadb = ${buildout:directory}/srv/mariadb
[init-script]
recipe = slapos.recipe.template:jinja2
# XXX: is there a better location ?
rendered = ${directory:etc}/mariadb_initial_setup.sql
template = inline:
{{ init_list | join('\n\t') }}
[
logrotate-mysql
]
[
{{ section('logrotate-mysql') }}
]
< = logrotate-entry-base
< = logrotate-entry-base
name = mariadb
name = mariadb
log = ${my-cnf-parameters:error-log} ${my-cnf-parameters:slow-query-log}
log = ${my-cnf-parameters:error-log} ${my-cnf-parameters:slow-query-log}
...
@@ -154,7 +170,9 @@ context =
...
@@ -154,7 +170,9 @@ context =
section my_cnf_parameters my-cnf-parameters
section my_cnf_parameters my-cnf-parameters
raw bin_directory {{ bin_directory }}
raw bin_directory {{ bin_directory }}
raw prepend_path ${mysqld:mysql-base-directory}/bin
raw prepend_path ${mysqld:mysql-base-directory}/bin
{% endif -%}
{%- endif %}
{%- endif %}
[buildout]
[buildout]
extends =
extends =
...
@@ -167,4 +185,3 @@ extends =
...
@@ -167,4 +185,3 @@ extends =
{%- endif %}
{%- endif %}
parts +=
parts +=
{{ '\n '.join(part_list) }}
{{ '\n '.join(part_list) }}
logrotate-mysql
software/neoppod/instance.cfg.in
View file @
d51a7948
...
@@ -12,14 +12,16 @@ extra-context =
...
@@ -12,14 +12,16 @@ extra-context =
import-list =
import-list =
rawfile root_common {{ root_common }}
rawfile root_common {{ root_common }}
[neo-storage-mysql]
{% if mariadb_location is defined -%}
[neo]
extra-context +=
extra-context +=
raw runTestSuite_in {{ runTestSuite_in }}
raw runTestSuite_in {{ runTestSuite_in }}
{% endif -%}
[switch-softwaretype]
[switch-softwaretype]
recipe = slapos.cookbook:switch-softwaretype
recipe = slapos.cookbook:switch-softwaretype
override = {{ dumps(override_switch_softwaretype |default) }}
override = {{ dumps(override_switch_softwaretype |default) }}
default = neo-cluster:rendered
default = neo-cluster:rendered
# BBB
# BBB
RootSoftwareInstance = ${:default}
RootSoftwareInstance = ${:default}
neo = neo
-storage-mysql
:rendered
neo = neo:rendered
software/neoppod/software-common.cfg
View file @
d51a7948
...
@@ -41,10 +41,10 @@ environment = neoppod-setup-env
...
@@ -41,10 +41,10 @@ environment = neoppod-setup-env
[neoppod]
[neoppod]
recipe = zc.recipe.egg
recipe = zc.recipe.egg
eggs = neoppod[admin, ctl, master
, storage-mysqldb
]
eggs = neoppod[admin, ctl, master]
${cython-zstd:egg}
${cython-zstd:egg}
${msgpack-python:egg}
${msgpack-python:egg}
${
python-mysqlclient:
egg}
${
:adapter-
egg}
psutil
psutil
BTrees
BTrees
ZODB
ZODB
...
@@ -52,6 +52,7 @@ eggs = neoppod[admin, ctl, master, storage-mysqldb]
...
@@ -52,6 +52,7 @@ eggs = neoppod[admin, ctl, master, storage-mysqldb]
zodbtools
zodbtools
coverage
coverage
setproctitle
setproctitle
adapter-egg = ${python-mysqlclient:egg}
patch-binary = ${patch:location}/bin/patch
patch-binary = ${patch:location}/bin/patch
ZEO-patch-options = -p1
ZEO-patch-options = -p1
ZEO-patches =
ZEO-patches =
...
@@ -81,16 +82,18 @@ mode = 644
...
@@ -81,16 +82,18 @@ mode = 644
recipe = slapos.recipe.template:jinja2
recipe = slapos.recipe.template:jinja2
template = ${:_profile_base_location_}/${:_buildout_section_name_}.cfg.in
template = ${:_profile_base_location_}/${:_buildout_section_name_}.cfg.in
rendered = ${buildout:directory}/${:_buildout_section_name_}.cfg
rendered = ${buildout:directory}/${:_buildout_section_name_}.cfg
md5sum =
e8f5a83580e9791a32c66f5935cb6840
md5sum =
b867ba222a436807954f732642fb116d
context =
context =
key bin_directory buildout:bin-directory
key bin_directory buildout:bin-directory
key develop_eggs_directory buildout:develop-eggs-directory
key develop_eggs_directory buildout:develop-eggs-directory
key eggs_directory buildout:eggs-directory
key eggs_directory buildout:eggs-directory
key mariadb_location mariadb:location
key neo_admin instance-neo-admin:target
key neo_admin instance-neo-admin:target
key neo_master instance-neo-master:target
key neo_master instance-neo-master:target
key neo
_storage_mysql instance-neo-storage-mysql
:target
key neo
instance-neo
:target
key template_logrotate_base template-logrotate-base:rendered
key template_logrotate_base template-logrotate-base:rendered
${:adapter-context}
adapter-context =
key mariadb_location mariadb:location
key template_neo_my_cnf template-neo-my-cnf:target
key template_neo_my_cnf template-neo-my-cnf:target
[root-common]
[root-common]
...
@@ -105,9 +108,9 @@ md5sum = 4d1ae570b4458e7725454857aabb37f6
...
@@ -105,9 +108,9 @@ md5sum = 4d1ae570b4458e7725454857aabb37f6
<= download-base-neo
<= download-base-neo
md5sum = 1fee10f02c2fa2a581e21878ca0fd704
md5sum = 1fee10f02c2fa2a581e21878ca0fd704
[instance-neo
-storage-mysql
]
[instance-neo]
<= download-base-neo
<= download-base-neo
md5sum =
16024af1cde9c0fcc7e8e05ec0854b30
md5sum =
a9e5cad9cdb5fd3f1ae7b1d534f967ae
[template-neo-my-cnf]
[template-neo-my-cnf]
<= download-base-neo
<= download-base-neo
...
...
software/neoppod/software.cfg
View file @
d51a7948
...
@@ -10,7 +10,7 @@ parts +=
...
@@ -10,7 +10,7 @@ parts +=
[template]
[template]
recipe = slapos.recipe.template:jinja2
recipe = slapos.recipe.template:jinja2
template = ${:_profile_base_location_}/instance.cfg.in
template = ${:_profile_base_location_}/instance.cfg.in
md5sum =
aaf5da66d45d4c08cadb0cd1c5342c54
md5sum =
83dc9faca482b2ddbd3d5fa968af7c33
# XXX: "template.cfg" is hardcoded in instanciation recipe
# XXX: "template.cfg" is hardcoded in instanciation recipe
rendered = ${buildout:directory}/template.cfg
rendered = ${buildout:directory}/template.cfg
context =
context =
...
@@ -18,6 +18,7 @@ context =
...
@@ -18,6 +18,7 @@ context =
key instance_common_cfg instance-common:rendered
key instance_common_cfg instance-common:rendered
key root_common root-common:target
key root_common root-common:target
key runTestSuite_in runTestSuite.in:target
key runTestSuite_in runTestSuite.in:target
${instance-common:adapter-context}
[cluster]
[cluster]
<= download-base-neo
<= download-base-neo
...
...
software/neoppod/sqlite-mixin.cfg
0 → 100644
View file @
d51a7948
# To be extended after software-common.cfg if only SQLite backend is wanted.
[neoppod]
adapter-egg =
[instance-common]
adapter-context =
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment