From 38d705fb52d8169ab6489addb9c3db9784bef40c Mon Sep 17 00:00:00 2001 From: Hugues Malphettes Date: Sat, 21 Nov 2015 16:30:16 +0800 Subject: [PATCH 1/2] fleetd: Add param --units_directory to customise the units directory The default location of the units directory for fleet is owned by root. When we use `systemd --user` we want this directory to be owned by a different user. Fixes #1393 --- config/config.go | 1 + fleetd/fleetd.go | 2 ++ server/server.go | 2 +- systemd/manager.go | 4 ---- 4 files changed, 4 insertions(+), 5 deletions(-) diff --git a/config/config.go b/config/config.go index 102c1257c..4d0cafd75 100644 --- a/config/config.go +++ b/config/config.go @@ -34,6 +34,7 @@ type Config struct { DisableEngine bool DisableWatches bool VerifyUnits bool + UnitsDirectory string AuthorizedKeysFile string } diff --git a/fleetd/fleetd.go b/fleetd/fleetd.go index 7232ab97d..0ea8dbfcb 100644 --- a/fleetd/fleetd.go +++ b/fleetd/fleetd.go @@ -86,6 +86,7 @@ func main() { cfgset.String("public_ip", "", "IP address that fleet machine should publish") cfgset.String("metadata", "", "List of key-value metadata to assign to the fleet machine") cfgset.String("agent_ttl", agent.DefaultTTL, "TTL in seconds of fleet machine state in etcd") + cfgset.String("units_directory", "/run/fleet/units/", "Path to the fleet units directory") cfgset.Int("token_limit", 100, "Maximum number of entries per page returned from API requests") cfgset.Bool("disable_engine", false, "Disable the engine entirely, use with care") cfgset.Bool("disable_watches", false, "Disable the use of etcd watches. Increases scheduling latency") @@ -225,6 +226,7 @@ func getConfig(flagset *flag.FlagSet, userCfgFile string) (*config.Config, error DisableEngine: (*flagset.Lookup("disable_engine")).Value.(flag.Getter).Get().(bool), DisableWatches: (*flagset.Lookup("disable_watches")).Value.(flag.Getter).Get().(bool), VerifyUnits: (*flagset.Lookup("verify_units")).Value.(flag.Getter).Get().(bool), + UnitsDirectory: (*flagset.Lookup("units_directory")).Value.(flag.Getter).Get().(string), TokenLimit: (*flagset.Lookup("token_limit")).Value.(flag.Getter).Get().(int), AuthorizedKeysFile: (*flagset.Lookup("authorized_keys_file")).Value.(flag.Getter).Get().(string), } diff --git a/server/server.go b/server/server.go index eb602b376..36d4ec7b7 100644 --- a/server/server.go +++ b/server/server.go @@ -75,7 +75,7 @@ func New(cfg config.Config, listeners []net.Listener) (*Server, error) { return nil, err } - mgr, err := systemd.NewSystemdUnitManager(systemd.DefaultUnitsDirectory) + mgr, err := systemd.NewSystemdUnitManager(cfg.UnitsDirectory) if err != nil { return nil, err } diff --git a/systemd/manager.go b/systemd/manager.go index f64f99565..b37d3aaf2 100644 --- a/systemd/manager.go +++ b/systemd/manager.go @@ -28,10 +28,6 @@ import ( "github.com/coreos/fleet/unit" ) -const ( - DefaultUnitsDirectory = "/run/fleet/units/" -) - type systemdUnitManager struct { systemd *dbus.Conn unitsDir string From 9b83262d732cb36202f1c69b6d537db1f2b1339e Mon Sep 17 00:00:00 2001 From: hmalphettes Date: Fri, 8 Jul 2016 16:31:38 +0800 Subject: [PATCH 2/2] fleetd: Add param -systemd_user=true to use `systemd --user` systemd offers users the ability to manage services under the user's control with a per-user systemd instance. This parameter enables fleet to target such instance of systemd. Fixes #1393 --- config/config.go | 1 + fleetd/fleetd.go | 2 ++ functional/systemd_test.go | 2 +- server/server.go | 2 +- systemd/manager.go | 11 +++++++++-- 5 files changed, 14 insertions(+), 4 deletions(-) diff --git a/config/config.go b/config/config.go index 4d0cafd75..a13cd265b 100644 --- a/config/config.go +++ b/config/config.go @@ -35,6 +35,7 @@ type Config struct { DisableWatches bool VerifyUnits bool UnitsDirectory string + SystemdUser bool AuthorizedKeysFile string } diff --git a/fleetd/fleetd.go b/fleetd/fleetd.go index 0ea8dbfcb..0d703e01b 100644 --- a/fleetd/fleetd.go +++ b/fleetd/fleetd.go @@ -87,6 +87,7 @@ func main() { cfgset.String("metadata", "", "List of key-value metadata to assign to the fleet machine") cfgset.String("agent_ttl", agent.DefaultTTL, "TTL in seconds of fleet machine state in etcd") cfgset.String("units_directory", "/run/fleet/units/", "Path to the fleet units directory") + cfgset.Bool("systemd_user", false, "When true use systemd --user)") cfgset.Int("token_limit", 100, "Maximum number of entries per page returned from API requests") cfgset.Bool("disable_engine", false, "Disable the engine entirely, use with care") cfgset.Bool("disable_watches", false, "Disable the use of etcd watches. Increases scheduling latency") @@ -227,6 +228,7 @@ func getConfig(flagset *flag.FlagSet, userCfgFile string) (*config.Config, error DisableWatches: (*flagset.Lookup("disable_watches")).Value.(flag.Getter).Get().(bool), VerifyUnits: (*flagset.Lookup("verify_units")).Value.(flag.Getter).Get().(bool), UnitsDirectory: (*flagset.Lookup("units_directory")).Value.(flag.Getter).Get().(string), + SystemdUser: (*flagset.Lookup("systemd_user")).Value.(flag.Getter).Get().(bool), TokenLimit: (*flagset.Lookup("token_limit")).Value.(flag.Getter).Get().(int), AuthorizedKeysFile: (*flagset.Lookup("authorized_keys_file")).Value.(flag.Getter).Get().(string), } diff --git a/functional/systemd_test.go b/functional/systemd_test.go index 3e020e692..eed8e4c49 100644 --- a/functional/systemd_test.go +++ b/functional/systemd_test.go @@ -35,7 +35,7 @@ func TestSystemdUnitFlow(t *testing.T) { } defer os.RemoveAll(uDir) - mgr, err := systemd.NewSystemdUnitManager(uDir) + mgr, err := systemd.NewSystemdUnitManager(uDir, false) if err != nil { t.Fatalf("Failed initializing SystemdUnitManager: %v", err) } diff --git a/server/server.go b/server/server.go index 36d4ec7b7..bf1c49f04 100644 --- a/server/server.go +++ b/server/server.go @@ -75,7 +75,7 @@ func New(cfg config.Config, listeners []net.Listener) (*Server, error) { return nil, err } - mgr, err := systemd.NewSystemdUnitManager(cfg.UnitsDirectory) + mgr, err := systemd.NewSystemdUnitManager(cfg.UnitsDirectory, cfg.SystemdUser) if err != nil { return nil, err } diff --git a/systemd/manager.go b/systemd/manager.go index b37d3aaf2..4c8aa1561 100644 --- a/systemd/manager.go +++ b/systemd/manager.go @@ -36,8 +36,8 @@ type systemdUnitManager struct { mutex sync.RWMutex } -func NewSystemdUnitManager(uDir string) (*systemdUnitManager, error) { - systemd, err := dbus.New() +func NewSystemdUnitManager(uDir string, systemdUser bool) (*systemdUnitManager, error) { + systemd, err := createDbusConnection(systemdUser) if err != nil { return nil, err } @@ -60,6 +60,13 @@ func NewSystemdUnitManager(uDir string) (*systemdUnitManager, error) { return &mgr, nil } +func createDbusConnection(systemdUser bool) (*dbus.Conn, error) { + if systemdUser { + return dbus.NewUserConnection() + } + return dbus.New() +} + func hashUnitFiles(dir string) (map[string]unit.Hash, error) { uNames, err := lsUnitsDir(dir) if err != nil {