rkt: update to 1.10.0.

This commit is contained in:
Andrea Brancaleoni 2016-07-09 09:57:39 +02:00
parent 48a7a5263b
commit cb75bfa476
2 changed files with 374 additions and 8 deletions

View file

@ -0,0 +1,362 @@
From 487aa645d09cd6aa650255aaf83bd76d81455299 Mon Sep 17 00:00:00 2001
From: Luca Bruno <luca.bruno@coreos.com>
Date: Mon, 4 Jul 2016 11:40:29 +0200
Subject: api_service: optionally build systemd-journal support
This introduces a 'sdjournal' tag and corresponding stubs in api_service,
turning libsystemd headers into a soft-dependency.
If systemd-journal support is enabled and `sd-journal.h` found at build
time, api_service will use it for logs retrieval.
This is enabled by default, but downstream can turn it off via
`--enable-sdjournal=no`.
---
Makefile.in | 2 +-
configure.ac | 39 +++++++++++++++---
rkt/api_service.go | 66 +-----------------------------
rkt/api_service_sdjournal.go | 96 ++++++++++++++++++++++++++++++++++++++++++++
rkt/api_service_stub.go | 27 +++++++++++++
rkt/rkt.mk | 6 ++-
6 files changed, 162 insertions(+), 74 deletions(-)
create mode 100644 rkt/api_service_sdjournal.go
create mode 100644 rkt/api_service_stub.go
diff --git a/Makefile.in b/Makefile.in
index db5636e..995bd1b 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -19,7 +19,7 @@ ABS_GO := @ABS_GO@
# [STAGE1] build settings
# selinux tags for rkt and functional tests
-RKT_TAGS := -tags "selinux @TPM_TAGS@"
+RKT_TAGS := -tags "selinux @TPM_TAGS@ @SDJOURNAL_TAGS@"
# stage1 build mode
RKT_VERSION := @RKT_VERSION@
diff --git a/configure.ac b/configure.ac
index 904e06e..3ec5d14 100644
--- a/configure.ac
+++ b/configure.ac
@@ -142,6 +142,14 @@ AC_ARG_ENABLE([tpm],
[RKT_ENABLE_TPM="${enableval}"],
[RKT_ENABLE_TPM="yes"])
+## Systemd-journal support on host
+
+AC_ARG_ENABLE([sdjournal],
+ [AS_HELP_STRING([--enable-sdjournal],
+ [enable systemd-journal features on host, use 'auto' to enable it if the required development files are found, default: 'yes'])],
+ [RKT_ENABLE_SDJOURNAL="${enableval}"],
+ [RKT_ENABLE_SDJOURNAL="yes"])
+
## insecure go
AC_ARG_ENABLE([insecure-go],
@@ -573,12 +581,6 @@ AC_CHECK_LIB([c], [fork],
# Check whether we can build TPM support code
AC_CHECK_HEADER(trousers/tss.h, [HAVE_TPM=yes], [HAVE_TPM=no], [AC_INCLUDES_DEFAULT])
-# Check whether we have libsystemd-journal (needed by the API server)
-AC_CHECK_HEADER([systemd/sd-journal.h],
- [],
- [AC_MSG_ERROR([*** No development headers for libsystemd-journal found])],
- [AC_INCLUDES_DEFAULT])
-
TPM_TAGS=''
AS_CASE([${RKT_ENABLE_TPM}],
[no],
@@ -600,6 +602,30 @@ AS_CASE([${RKT_ENABLE_TPM}],
[yes],
[RKT_ADD_FEATURE '+TPM'])
+# Check whether we have libsystemd-journal (for go-systemd/sdjournal)
+AC_CHECK_HEADER([systemd/sd-journal.h], [HAVE_SDJOURNAL=yes], [HAVE_SDJOURNAL=no], [AC_INCLUDES_DEFAULT])
+
+SDJOURNAL_TAGS=''
+AS_CASE([${RKT_ENABLE_SDJOURNAL}],
+ [no],
+ dnl nothing to do
+ [:],
+ [auto],
+ [AS_VAR_IF([HAVE_SDJOURNAL],[yes],
+ [SDJOURNAL_TAGS=sdjournal
+ RKT_ENABLE_SDJOURNAL=yes],
+ [RKT_ENABLE_SDJOURNAL=no])],
+ [yes],
+ [AS_VAR_IF([HAVE_SDJOURNAL],[no],
+ [AC_MSG_ERROR([*** Host systemd-journal support enabled, but could not find required development files])])
+ SDJOURNAL_TAGS=sdjournal],
+ [AC_MSG_ERROR([*** Invalid value passed to --enable-sdjournal, should be either 'yes', 'no' or 'auto'])])
+AS_CASE([${RKT_ENABLE_SDJOURNAL}],
+ [no],
+ [RKT_ADD_FEATURE '-SDJOURNAL'],
+ [yes],
+ [RKT_ADD_FEATURE '+SDJOURNAL'])
+
AC_LANG_POP([C])
AC_PROG_INSTALL
@@ -696,6 +722,7 @@ AC_SUBST(RKT_VERSION_LDFLAGS)
AC_SUBST(RKT_FEATURES_LDFLAGS)
AC_SUBST(TPM_TAGS)
+AC_SUBST(SDJOURNAL_TAGS)
AC_SUBST(RKT_DEFINES_FOR_ENTER)
diff --git a/rkt/api_service.go b/rkt/api_service.go
index f7eb381..65b4ca2 100644
--- a/rkt/api_service.go
+++ b/rkt/api_service.go
@@ -18,7 +18,6 @@ import (
"encoding/json"
"errors"
"fmt"
- "io/ioutil"
"net"
"os"
"os/signal"
@@ -30,7 +29,6 @@ import (
"github.com/appc/spec/schema"
"github.com/appc/spec/schema/types"
- "github.com/coreos/go-systemd/sdjournal"
"github.com/coreos/rkt/api/v1alpha"
"github.com/coreos/rkt/common"
"github.com/coreos/rkt/common/cgroup"
@@ -744,69 +742,7 @@ func (sw LogsStreamWriter) Write(b []byte) (int, error) {
}
func (s *v1AlphaAPIServer) GetLogs(request *v1alpha.GetLogsRequest, server v1alpha.PublicAPI_GetLogsServer) error {
- uuid, err := types.NewUUID(request.PodId)
- if err != nil {
- return err
- }
- pod, err := getPod(uuid)
- if err != nil {
- return err
- }
- stage1Path := "stage1/rootfs"
- if pod.usesOverlay() {
- stage1TreeStoreID, err := pod.getStage1TreeStoreID()
- if err != nil {
- return err
- }
- stage1Path = fmt.Sprintf("/overlay/%s/upper/", stage1TreeStoreID)
- }
- path := filepath.Join(getDataDir(), "/pods/run/", request.PodId, stage1Path, "/var/log/journal/")
-
- if _, err := os.Stat(path); os.IsNotExist(err) {
- return fmt.Errorf("%s: logging unsupported", uuid.String())
- }
-
- jconf := sdjournal.JournalReaderConfig{
- Path: path,
- }
- if request.AppName != "" {
- jconf.Matches = []sdjournal.Match{
- {
- Field: sdjournal.SD_JOURNAL_FIELD_SYSLOG_IDENTIFIER,
- Value: request.AppName,
- },
- }
- }
- if request.SinceTime != 0 {
- t := time.Unix(request.SinceTime, 0)
- jconf.Since = -time.Since(t)
- }
- if request.Lines != 0 {
- jconf.NumFromTail = uint64(request.Lines)
- }
-
- jr, err := sdjournal.NewJournalReader(jconf)
- if err != nil {
- return err
- }
- defer jr.Close()
-
- if request.Follow {
- return jr.Follow(nil, LogsStreamWriter{server: server})
- }
-
- data, err := ioutil.ReadAll(jr)
- if err != nil {
- return err
- }
- // Remove empty lines
- lines := make([]string, 0)
- for _, v := range strings.Split(string(data), "\n") {
- if len(v) > 0 {
- lines = append(lines, v)
- }
- }
- return server.Send(&v1alpha.GetLogsResponse{Lines: lines})
+ return s.constrainedGetLogs(request, server)
}
func (s *v1AlphaAPIServer) ListenEvents(request *v1alpha.ListenEventsRequest, server v1alpha.PublicAPI_ListenEventsServer) error {
diff --git a/rkt/api_service_sdjournal.go b/rkt/api_service_sdjournal.go
new file mode 100644
index 0000000..12aabb1
--- /dev/null
+++ b/rkt/api_service_sdjournal.go
@@ -0,0 +1,96 @@
+// Copyright 2016 The rkt Authors
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+// +build sdjournal
+
+package main
+
+import (
+ "fmt"
+ "io/ioutil"
+ "os"
+ "path/filepath"
+ "strings"
+ "time"
+
+ "github.com/appc/spec/schema/types"
+ "github.com/coreos/go-systemd/sdjournal"
+ "github.com/coreos/rkt/api/v1alpha"
+)
+
+func (s *v1AlphaAPIServer) constrainedGetLogs(request *v1alpha.GetLogsRequest, server v1alpha.PublicAPI_GetLogsServer) error {
+ uuid, err := types.NewUUID(request.PodId)
+ if err != nil {
+ return err
+ }
+ pod, err := getPod(uuid)
+ if err != nil {
+ return err
+ }
+ stage1Path := "stage1/rootfs"
+ if pod.usesOverlay() {
+ stage1TreeStoreID, err := pod.getStage1TreeStoreID()
+ if err != nil {
+ return err
+ }
+ stage1Path = fmt.Sprintf("/overlay/%s/upper/", stage1TreeStoreID)
+ }
+ path := filepath.Join(getDataDir(), "/pods/run/", request.PodId, stage1Path, "/var/log/journal/")
+
+ if _, err := os.Stat(path); os.IsNotExist(err) {
+ return fmt.Errorf("%s: logging unsupported", uuid.String())
+ }
+
+ jconf := sdjournal.JournalReaderConfig{
+ Path: path,
+ }
+ if request.AppName != "" {
+ jconf.Matches = []sdjournal.Match{
+ {
+ Field: sdjournal.SD_JOURNAL_FIELD_SYSLOG_IDENTIFIER,
+ Value: request.AppName,
+ },
+ }
+ }
+ if request.SinceTime != 0 {
+ t := time.Unix(request.SinceTime, 0)
+ jconf.Since = -time.Since(t)
+ }
+ if request.Lines != 0 {
+ jconf.NumFromTail = uint64(request.Lines)
+ }
+
+ jr, err := sdjournal.NewJournalReader(jconf)
+ if err != nil {
+ return err
+ }
+ defer jr.Close()
+
+ if request.Follow {
+ return jr.Follow(nil, LogsStreamWriter{server: server})
+ }
+
+ data, err := ioutil.ReadAll(jr)
+ if err != nil {
+ return err
+ }
+ // Remove empty lines
+ lines := make([]string, 0)
+ for _, v := range strings.Split(string(data), "\n") {
+ if len(v) > 0 {
+ lines = append(lines, v)
+ }
+ }
+ return server.Send(&v1alpha.GetLogsResponse{Lines: lines})
+}
diff --git a/rkt/api_service_stub.go b/rkt/api_service_stub.go
new file mode 100644
index 0000000..5a1c743
--- /dev/null
+++ b/rkt/api_service_stub.go
@@ -0,0 +1,27 @@
+// Copyright 2016 The rkt Authors
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+// +build !sdjournal
+
+package main
+
+import (
+ "fmt"
+
+ "github.com/coreos/rkt/api/v1alpha"
+)
+
+func (s *v1AlphaAPIServer) constrainedGetLogs(request *v1alpha.GetLogsRequest, server v1alpha.PublicAPI_GetLogsServer) error {
+ return fmt.Errorf("rkt built without logging support")
+}
diff --git a/rkt/rkt.mk b/rkt/rkt.mk
index 6e9dd73..1d95bc0 100644
--- a/rkt/rkt.mk
+++ b/rkt/rkt.mk
@@ -29,18 +29,20 @@ $(BGB_BINARY): $(MK_PATH) | $(TARGET_BINDIR)
include makelib/build_go_bin.mk
+DIST_SRC_FILTER := '_test.go|main.go|_gen.go|_stub.go'
+
manpages: GO_ENV += GOARCH=$(GOARCH_FOR_BUILD) CC=$(CC_FOR_BUILD)
manpages: | $(GOPATH_TO_CREATE)/src/$(REPO_PATH)
mkdir -p dist/manpages/
ls $(GOPATH_TO_CREATE)/src/$(REPO_PATH)/rkt/*.go | \
- grep -vE '_test.go|main.go|_gen.go' | \
+ grep -vE $(DIST_SRC_FILTER) | \
$(GO_ENV) xargs "$(GO)" run $(GOPATH_TO_CREATE)/src/$(REPO_PATH)/rkt/manpages_gen.go
bash-completion: GO_ENV += GOARCH=$(GOARCH_FOR_BUILD) CC=$(CC_FOR_BUILD)
bash-completion: | $(GOPATH_TO_CREATE)/src/$(REPO_PATH)
mkdir -p dist/bash_completion/
ls $(GOPATH_TO_CREATE)/src/$(REPO_PATH)/rkt/*.go | \
- grep -vE '_test.go|main.go|_gen.go' | \
+ grep -vE $(DIST_SRC_FILTER) | \
$(GO_ENV) xargs "$(GO)" run $(GOPATH_TO_CREATE)/src/$(REPO_PATH)/rkt/bash_completion_gen.go
protobuf:
--
2.9.0

View file

@ -1,6 +1,6 @@
# Template file for 'rkt'
pkgname=rkt
version=1.6.0
version=1.10.0
revision=1
build_style=gnu-configure
hostmakedepends="automake wget cpio squashfs-tools bc gnupg git go"
@ -11,10 +11,14 @@ maintainer="Andrea Brancaleoni <miwaxe@gmail.com>"
license="Apache-2.0"
homepage="https://github.com/coreos/rkt"
distfiles="$homepage/archive/v$version.tar.gz"
checksum=767f2ed21d6dbf00a7a264d0dbd84a2733d56dbe97bab90b3d99af47d33c9b5c
checksum=5f282afccbddeb012e067c2f27bd552a86849115fc2660cba56c453de46b9852
patch_args="-Np1"
nopie=yes
configure_args="--enable-tpm=no
--with-stage1-flavors=fly,kvm,coreos
--enable-sdjournal=no
--with-stage1-flavors=fly,kvm,coreos,host
--with-stage1-default-location=/usr/lib/rkt/stage1.aci"
system_groups="rkt"
@ -52,8 +56,8 @@ do_install() {
vinstall ${FILESDIR}/rkt-gc 755 etc/cron.daily
vbin build-${pkgname}-${version}/bin/rkt
vbin build-${pkgname}-${version}/bin/actool
vbin build-${pkgname}-${version}/target/bin/rkt
vbin build-${pkgname}-${version}/tools/actool
}
rkt-stage1-fly_package() {
@ -62,7 +66,7 @@ rkt-stage1-fly_package() {
short_desc+=" - fly stage1"
provides="rkt-stage1-${version}_${revision}"
pkg_install() {
vinstall build-${sourcepkg}-${version}/bin/stage1-fly.aci 644 usr/lib/rkt
vinstall build-${sourcepkg}-${version}/target/bin/stage1-fly.aci 644 usr/lib/rkt
}
}
@ -72,7 +76,7 @@ rkt-stage1-kvm_package() {
short_desc+=" - kvm stage1"
provides="rkt-stage1-${version}_${revision}"
pkg_install() {
vinstall build-${sourcepkg}-${version}/bin/stage1-kvm.aci 644 usr/lib/rkt
vinstall build-${sourcepkg}-${version}/target/bin/stage1-kvm.aci 644 usr/lib/rkt
}
}
@ -82,6 +86,6 @@ rkt-stage1-coreos_package() {
short_desc+=" - coreos stage1"
provides="rkt-stage1-${version}_${revision}"
pkg_install() {
vinstall build-${sourcepkg}-${version}/bin/stage1-coreos.aci 644 usr/lib/rkt
vinstall build-${sourcepkg}-${version}/target/bin/stage1-coreos.aci 644 usr/lib/rkt
}
}