significado erlang mnesia

erlang - significado - mnesia elixir



Cómo cambiar el nombre del nodo ejecutando una base de datos de mnesia (2)

La solución alternativa es la migración. Simplemente inicie el clúster de mnesia y migre todas sus tablas y esquemas a otro nodo. Que eliminar del original y se olvidó.

Creé una base de datos / esquema de Mnesia en machine1. El nodo se denominó mypl @ machine1. Luego moví todos los archivos a machine2, porque la máquina 1 se averió. Todo funciona bien siempre que el código se ejecute con el nombre "mypl @ machine1". Obviamente esto es algo confuso, porque ahora se está ejecutando en machine2.

Si comienzo Erlang con el nombre de nodo "mypl @ machine2", la base de datos Mnesia aparece vacía.

¿Cómo cambio el nombre del nodo en una Base de datos de Mnesia de machine1 a machine2?


No creo que esto pueda hacerse en línea en un solo nodo (¿alguien?), Pero es posible hacerlo a través de una copia de seguridad / restauración, además de ejecutar dos nodos y agregar copias de tabla. En la guía de usuario de Mnesia, sección 6.9.1, encontrará un código que usa mnesia: traverse_backup para alterar los nombres de los nodos en la tabla de esquema (mostrada a continuación) en un archivo de copia de seguridad de mnesia. El nombre del módulo que probablemente deba usar es mnesia_backup .

Con este código, necesitarás:

%% On mypl@machine1 mnesia:backup("/path/to/mnesia.backup"). change_node_name(mnesia_backup, mypl@machine1, mypl@machine2, "/path/to/mnesia.backup", "/path/to/new.mnesia.backup"). %% On mypl@machine2 mnesia:restore("/path/to/new.mnesia.backup", []).

No estoy seguro si necesita crear el esquema primero en mypl@machine2 .

El código de nombre de nodo de cambio de la guía del usuario:

change_node_name(Mod, From, To, Source, Target) -> Switch = fun(Node) when Node == From -> To; (Node) when Node == To -> throw({error, already_exists}); (Node) -> Node end, Convert = fun({schema, db_nodes, Nodes}, Acc) -> {[{schema, db_nodes, lists:map(Switch,Nodes)}], Acc}; ({schema, version, Version}, Acc) -> {[{schema, version, Version}], Acc}; ({schema, cookie, Cookie}, Acc) -> {[{schema, cookie, Cookie}], Acc}; ({schema, Tab, CreateList}, Acc) -> Keys = [ram_copies, disc_copies, disc_only_copies], OptSwitch = fun({Key, Val}) -> case lists:member(Key, Keys) of true -> {Key, lists:map(Switch, Val)}; false-> {Key, Val} end end, {[{schema, Tab, lists:map(OptSwitch, CreateList)}], Acc}; (Other, Acc) -> {[Other], Acc} end, mnesia:traverse_backup(Source, Mod, Target, Mod, Convert, switched).