mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
system_id: new appmachineid option
The new system_id_source="appmachineid" will cause lvm to use an lvm-specific derivation of the machine-id, instead of the machine-id directly. This is now recommended in place of using machineid. (cherry picked from commit 9f73ead7d42597cc8eb57fd0b63af050eece0718)
This commit is contained in:
parent
e2ecc426ac
commit
3d5418c9c6
20
configure.ac
20
configure.ac
@ -1084,6 +1084,26 @@ if test "$NOTIFYDBUS_SUPPORT" = yes; then
|
|||||||
PKG_CHECK_MODULES(NOTIFY_DBUS, systemd >= 221, [HAVE_NOTIFY_DBUS=yes], $bailout)
|
PKG_CHECK_MODULES(NOTIFY_DBUS, systemd >= 221, [HAVE_NOTIFY_DBUS=yes], $bailout)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
dnl -- Build appmachineid
|
||||||
|
AC_MSG_CHECKING(whether to build appmachineid)
|
||||||
|
AC_ARG_ENABLE(app-machineid,
|
||||||
|
AC_HELP_STRING([--enable-app-machineid],
|
||||||
|
[enable LVM system ID using app-specific machine-id]),
|
||||||
|
APP_MACHINEID_SUPPORT=$enableval, APP_MACHINEID_SUPPORT=no)
|
||||||
|
AC_MSG_RESULT($APP_MACHINEID_SUPPORT)
|
||||||
|
|
||||||
|
if test "$APP_MACHINEID_SUPPORT" = yes; then
|
||||||
|
AC_DEFINE([APP_MACHINEID_SUPPORT], 1, [Define to 1 to include code that uses libsystemd machine-id apis.])
|
||||||
|
SYSTEMD_LIBS="-lsystemd"
|
||||||
|
fi
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
dnl -- Look for libsystemd libraries
|
||||||
|
if test "$APP_MACHINEID_SUPPORT" = yes; then
|
||||||
|
PKG_CHECK_MODULES(APP_MACHINEID, systemd >= 234, [HAVE_APP_MACHINEID=yes], $bailout)
|
||||||
|
fi
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
dnl -- Enable blkid wiping functionality
|
dnl -- Enable blkid wiping functionality
|
||||||
|
@ -41,6 +41,10 @@
|
|||||||
#include <syslog.h>
|
#include <syslog.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
|
#ifdef APP_MACHINEID_SUPPORT
|
||||||
|
#include <systemd/sd-id128.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
# include <malloc.h>
|
# include <malloc.h>
|
||||||
#endif
|
#endif
|
||||||
@ -129,9 +133,12 @@ static const char *_read_system_id_from_file(struct cmd_context *cmd, const char
|
|||||||
return system_id;
|
return system_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* systemd-id128 new produced: f64406832c2140e8ac5422d1089aae03 */
|
||||||
|
#define LVM_APPLICATION_ID SD_ID128_MAKE(f6,44,06,83,2c,21,40,e8,ac,54,22,d1,08,9a,ae,03)
|
||||||
|
|
||||||
static const char *_system_id_from_source(struct cmd_context *cmd, const char *source)
|
static const char *_system_id_from_source(struct cmd_context *cmd, const char *source)
|
||||||
{
|
{
|
||||||
char filebuf[PATH_MAX];
|
char buf[PATH_MAX];
|
||||||
const char *file;
|
const char *file;
|
||||||
const char *etc_str;
|
const char *etc_str;
|
||||||
const char *str;
|
const char *str;
|
||||||
@ -150,10 +157,23 @@ static const char *_system_id_from_source(struct cmd_context *cmd, const char *s
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef APP_MACHINEID_SUPPORT
|
||||||
|
if (!strcasecmp(source, "appmachineid")) {
|
||||||
|
sd_id128_t id;
|
||||||
|
|
||||||
|
sd_id128_get_machine_app_specific(LVM_APPLICATION_ID, &id);
|
||||||
|
|
||||||
|
if (dm_snprintf(buf, PATH_MAX, SD_ID128_FORMAT_STR, SD_ID128_FORMAT_VAL(id)) < 0)
|
||||||
|
stack;
|
||||||
|
system_id = system_id_from_string(cmd, buf);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (!strcasecmp(source, "machineid") || !strcasecmp(source, "machine-id")) {
|
if (!strcasecmp(source, "machineid") || !strcasecmp(source, "machine-id")) {
|
||||||
etc_str = find_config_tree_str(cmd, global_etc_CFG, NULL);
|
etc_str = find_config_tree_str(cmd, global_etc_CFG, NULL);
|
||||||
if (dm_snprintf(filebuf, sizeof(filebuf), "%s/machine-id", etc_str) != -1)
|
if (dm_snprintf(buf, sizeof(buf), "%s/machine-id", etc_str) != -1)
|
||||||
system_id = _read_system_id_from_file(cmd, filebuf);
|
system_id = _read_system_id_from_file(cmd, buf);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1281,10 +1281,12 @@ cfg(global_system_id_source_CFG, "system_id_source", global_CFG_SECTION, CFG_DEF
|
|||||||
" uname\n"
|
" uname\n"
|
||||||
" Set the system ID from the hostname (uname) of the system.\n"
|
" Set the system ID from the hostname (uname) of the system.\n"
|
||||||
" System IDs beginning localhost are not permitted.\n"
|
" System IDs beginning localhost are not permitted.\n"
|
||||||
|
" appmachineid\n"
|
||||||
|
" Use an LVM-specific derivation of the local machine-id as the\n"
|
||||||
|
" system ID. See 'man machine-id'.\n"
|
||||||
" machineid\n"
|
" machineid\n"
|
||||||
" Use the contents of the machine-id file to set the system ID.\n"
|
" Use the contents of the machine-id file to set the system ID\n"
|
||||||
" Some systems create this file at installation time.\n"
|
" (appmachineid is recommended.)\n"
|
||||||
" See 'man machine-id' and global/etc.\n"
|
|
||||||
" file\n"
|
" file\n"
|
||||||
" Use the contents of another file (system_id_file) to set the\n"
|
" Use the contents of another file (system_id_file) to set the\n"
|
||||||
" system ID.\n"
|
" system ID.\n"
|
||||||
|
@ -172,6 +172,22 @@ global {
|
|||||||
}
|
}
|
||||||
.fi
|
.fi
|
||||||
.
|
.
|
||||||
|
.TP
|
||||||
|
.B appmachineid
|
||||||
|
.br
|
||||||
|
|
||||||
|
An LVM-specific derivation of /etc/machine-id is used as the system ID.
|
||||||
|
See
|
||||||
|
.BR machine-id (5)
|
||||||
|
to check if machine-id is available on the host.
|
||||||
|
|
||||||
|
.I lvm.conf
|
||||||
|
.nf
|
||||||
|
global {
|
||||||
|
system_id_source = "appmachineid"
|
||||||
|
}
|
||||||
|
.fi
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
.B machineid
|
.B machineid
|
||||||
.br
|
.br
|
||||||
@ -181,6 +197,7 @@ See
|
|||||||
and
|
and
|
||||||
.BR systemd-machine-id-setup (1)
|
.BR systemd-machine-id-setup (1)
|
||||||
to check if machine-id is available on the host.
|
to check if machine-id is available on the host.
|
||||||
|
(appmachineid is recommended in place of machineid.)
|
||||||
.sp
|
.sp
|
||||||
.I lvm.conf
|
.I lvm.conf
|
||||||
.nf
|
.nf
|
||||||
|
@ -50,6 +50,17 @@ check vg_field $vg1 systemid "$SID"
|
|||||||
vgremove $vg1
|
vgremove $vg1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
## appmachineid
|
||||||
|
lvm version > lvmver
|
||||||
|
if grep app-machineid lvmver; then
|
||||||
|
aux lvmconf "global/system_id_source = appmachineid"
|
||||||
|
lvm systemid | awk '{ print $3 }' > sid_lvm
|
||||||
|
vgcreate $vg1 "$dev1"
|
||||||
|
vgs -o systemid --noheadings $vg1 | awk '{print $1}' > sid_vg
|
||||||
|
diff sid_lvm sid_vg
|
||||||
|
vgremove $vg1
|
||||||
|
fi
|
||||||
|
|
||||||
## uname
|
## uname
|
||||||
|
|
||||||
SID1=$(uname -n)
|
SID1=$(uname -n)
|
||||||
|
Loading…
Reference in New Issue
Block a user