Skip to content

Commit

Permalink
Fixed marklogic-community#366: added bootstrap/wipe for internal repl…
Browse files Browse the repository at this point in the history
…icas
  • Loading branch information
grtjn committed Feb 24, 2015
1 parent a449ac0 commit eecdf37
Show file tree
Hide file tree
Showing 2 changed files with 112 additions and 5 deletions.
5 changes: 5 additions & 0 deletions deploy/default.properties
Original file line number Diff line number Diff line change
Expand Up @@ -205,3 +205,8 @@ mlcp-vmargs=-Xmx512m
# Temporary fix to support MarkLogic 8 EA2
#
evaler-port=7998

#
# List of MarkLogic system databases, for replication
#
system-dbs=App-Services,Documents,Extensions,Fab,Last-Login,Meters,Modules,Schemas,Security,Triggers
112 changes: 107 additions & 5 deletions deploy/lib/server_config.rb
Original file line number Diff line number Diff line change
Expand Up @@ -447,9 +447,76 @@ def config
def bootstrap
raise ExitException.new("Bootstrap requires the target environment's hostname to be defined") unless @hostname.present?

logger.info "Bootstrapping your project into MarkLogic #{@properties['ml.server-version']} on #{@hostname}..."
internals = find_arg(['--replicate-internals'])
if internals

nr = find_arg(['--nr-replicas'])
if nr
nr = nr.to_i
else
nr = 2
end

# check cluster size
r = execute_query %Q{ fn:count(xdmp:hosts()) }
r.body = parse_json(r.body)
raise ExitException.new("Increase nr-replicas, minimum is 1") if nr < 1
raise ExitException.new("Adding #{nr} replicas to internals requires at least a #{nr + 1} node cluster") if r.body.to_i <= nr

logger.info "Bootstrapping replicas for #{@properties['ml.system-dbs']} on #{@hostname}..."

# build custom ml-config
assigns = ''
internals = @properties['ml.system-dbs'].split ','
internals.each do |db|
repnames = ''
repassigns = ''
(1..nr).each do |i|
repnames = repnames + %Q{
<replica-name>#{db}-rep#{i}</replica-name>}
repassigns = repassigns + %Q{
<assignment>
<forest-name>#{db}-rep#{i}</forest-name>
</assignment>}
end

assigns = assigns + %Q{
<!-- #{db} -->
<assignment>
<forest-name>#{db}</forest-name>
<replica-names>#{repnames}
</replica-names>
</assignment>#{repassigns}}
end
databases = ''
internals.each do |db|
databases = databases + %Q{
<!-- #{db} -->
<database>
<database-name>#{db}</database-name>
<forests>
<forest-id name="#{db}"/>
</forests>
</database>}
end
config = %Q{
<configuration default-group="#{@properties['ml.group']}">
<assignments xmlns="http://marklogic.com/xdmp/assignments">#{assigns}
</assignments>
<databases xmlns="http://marklogic.com/xdmp/database">#{databases}
</databases>
</configuration>
}
logger.debug config
else
logger.info "Bootstrapping your project into MarkLogic #{@properties['ml.server-version']} on #{@hostname}..."
config = get_config
end

setup = File.read(ServerConfig.expand_path("#{@@path}/lib/xquery/setup.xqy"))
r = execute_query %Q{#{setup} setup:do-setup(#{get_config})}
r = execute_query %Q{#{setup} setup:do-setup(#{config})}
logger.debug "code: #{r.code.to_i}"

r.body = parse_json(r.body)
Expand Down Expand Up @@ -492,6 +559,7 @@ def wipe
end

appbuilder = find_arg(['--app-builder'])
internals = find_arg(['--internal-replicas'])
setup = File.read(ServerConfig.expand_path("#{@@path}/lib/xquery/setup.xqy"))

if (appbuilder != nil)
Expand All @@ -518,7 +586,7 @@ def wipe
</databases>
</configuration>
}
else
elsif (internals == nil)
databases = find_arg(['--databases']) || '##none##'
forests = find_arg(['--forests']) || '##none##'
servers = find_arg(['--servers']) || '##none##'
Expand Down Expand Up @@ -556,8 +624,42 @@ def wipe
end
end

#logger.debug %Q{#{setup} setup:do-wipe(#{config})}
r = execute_query %Q{#{setup} setup:do-wipe(#{config})}
if (internals != nil)
logger.info "Wiping replicas for #{@properties['ml.system-dbs']} from #{@hostname}.."
r = execute_query %Q{
xquery version "1.0-ml";
import module namespace admin = "http://marklogic.com/xdmp/admin"
at "/MarkLogic/admin.xqy";
let $admin-config := admin:get-configuration()
let $replicas :=
for $forest-name in (#{quote_arglist(@properties['ml.system-dbs'])})
let $forest-id := admin:forest-get-id($admin-config, $forest-name)
for $replica in admin:forest-get-replicas($admin-config, $forest-id)
return (
xdmp:set(
$admin-config,
admin:forest-remove-replica($admin-config, $forest-id, $replica)
),
$replica
)
let $_ :=
for $replica in $replicas
return xdmp:set(
$admin-config,
admin:forest-delete($admin-config, $replica, fn:true())
)
return
if (admin:save-configuration-without-restart($admin-config)) then
"(note: restart required)"
else ()
}
else
#logger.debug %Q{#{setup} setup:do-wipe(#{config})}
r = execute_query %Q{#{setup} setup:do-wipe(#{config})}
end
logger.debug "code: #{r.code.to_i}"

r.body = parse_json(r.body)
Expand Down

0 comments on commit eecdf37

Please sign in to comment.