]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/journal/journald-server.h
journal: asynchronous journal_file_set_offline()
[thirdparty/systemd.git] / src / journal / journald-server.h
CommitLineData
c2f1db8f 1#pragma once
e6960940
LP
2
3/***
4 This file is part of systemd.
5
6 Copyright 2011 Lennart Poettering
7
8 systemd is free software; you can redistribute it and/or modify it
5430f7f2
LP
9 under the terms of the GNU Lesser General Public License as published by
10 the Free Software Foundation; either version 2.1 of the License, or
e6960940
LP
11 (at your option) any later version.
12
13 systemd is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5430f7f2 16 Lesser General Public License for more details.
e6960940 17
5430f7f2 18 You should have received a copy of the GNU Lesser General Public License
e6960940
LP
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
20***/
21
e6960940 22#include <stdbool.h>
b1bafc00 23#include <sys/types.h>
e6960940 24
f9a810be 25#include "sd-event.h"
430f0182 26
e22aa3d3
LP
27typedef struct Server Server;
28
e6960940 29#include "hashmap.h"
430f0182 30#include "journal-file.h"
d2bd7630 31#include "journald-rate-limit.h"
e22aa3d3 32#include "journald-stream.h"
e6960940
LP
33#include "list.h"
34
e156d769
LP
35typedef enum Storage {
36 STORAGE_AUTO,
37 STORAGE_VOLATILE,
205c4d1d 38 STORAGE_PERSISTENT,
e156d769
LP
39 STORAGE_NONE,
40 _STORAGE_MAX,
41 _STORAGE_INVALID = -1
42} Storage;
43
182b858f 44typedef enum SplitMode {
182b858f 45 SPLIT_UID,
edc3797f 46 SPLIT_LOGIN,
182b858f
LP
47 SPLIT_NONE,
48 _SPLIT_MAX,
49 _SPLIT_INVALID = -1
50} SplitMode;
51
e22aa3d3 52struct Server {
e6960940
LP
53 int syslog_fd;
54 int native_fd;
55 int stdout_fd;
51abe64c 56 int dev_kmsg_fd;
875c2e22 57 int audit_fd;
0c24bb23 58 int hostname_fd;
e22aa3d3 59 int notify_fd;
e6960940 60
f9a810be
LP
61 sd_event *event;
62
63 sd_event_source *syslog_event_source;
64 sd_event_source *native_event_source;
65 sd_event_source *stdout_event_source;
66 sd_event_source *dev_kmsg_event_source;
875c2e22 67 sd_event_source *audit_event_source;
f9a810be
LP
68 sd_event_source *sync_event_source;
69 sd_event_source *sigusr1_event_source;
70 sd_event_source *sigusr2_event_source;
71 sd_event_source *sigterm_event_source;
72 sd_event_source *sigint_event_source;
94b65516 73 sd_event_source *sigrtmin1_event_source;
0c24bb23 74 sd_event_source *hostname_event_source;
e22aa3d3 75 sd_event_source *notify_event_source;
119e9655 76 sd_event_source *watchdog_event_source;
f9a810be 77
e6960940
LP
78 JournalFile *runtime_journal;
79 JournalFile *system_journal;
43cf8388 80 OrderedHashmap *user_journals;
e6960940
LP
81
82 uint64_t seqnum;
83
84 char *buffer;
85 size_t buffer_size;
86
87 JournalRateLimit *rate_limit;
26687bf8 88 usec_t sync_interval_usec;
e6960940
LP
89 usec_t rate_limit_interval;
90 unsigned rate_limit_burst;
91
92 JournalMetrics runtime_metrics;
93 JournalMetrics system_metrics;
94
95 bool compress;
eb53b74f 96 bool seal;
e6960940 97
224f2ee2
LP
98 bool forward_to_kmsg;
99 bool forward_to_syslog;
100 bool forward_to_console;
40b71e89 101 bool forward_to_wall;
224f2ee2 102
178cc770
LP
103 unsigned n_forward_syslog_missed;
104 usec_t last_warn_forward_syslog_missed;
105
8580d1f7
LP
106 uint64_t cached_space_available;
107 uint64_t cached_space_limit;
108 usec_t cached_space_timestamp;
e6960940
LP
109
110 uint64_t var_available_timestamp;
111
fb0951b0
LP
112 usec_t max_retention_usec;
113 usec_t max_file_usec;
114 usec_t oldest_file_usec;
115
e6960940 116 LIST_HEAD(StdoutStream, stdout_streams);
e22aa3d3 117 LIST_HEAD(StdoutStream, stdout_streams_notify_queue);
e6960940 118 unsigned n_stdout_streams;
0d9243f0
LP
119
120 char *tty_path;
213ba152
LP
121
122 int max_level_store;
123 int max_level_syslog;
124 int max_level_kmsg;
125 int max_level_console;
40b71e89 126 int max_level_wall;
e156d769
LP
127
128 Storage storage;
182b858f 129 SplitMode split_mode;
51abe64c 130
16e9f408
LP
131 MMapCache *mmap;
132
119e9655 133 struct udev *udev;
cee5e9a7
LP
134
135 uint64_t *kernel_seqnum;
119e9655 136 bool dev_kmsg_readable:1;
bdfb9e7f 137
119e9655
LP
138 bool send_watchdog:1;
139 bool sent_notify_ready:1;
140 bool sync_scheduled:1;
0c24bb23
LP
141
142 char machine_id_field[sizeof("_MACHINE_ID=") + 32];
143 char boot_id_field[sizeof("_BOOT_ID=") + 32];
144 char *hostname_field;
e9174f29
LP
145
146 /* Cached cgroup root, so that we don't have to query that all the time */
147 char *cgroup_root;
119e9655
LP
148
149 usec_t watchdog_usec;
e22aa3d3 150};
e6960940 151
8580d1f7
LP
152#define SERVER_MACHINE_ID(s) ((s)->machine_id_field + strlen("_MACHINE_ID="))
153
0a244b8e 154#define N_IOVEC_META_FIELDS 20
ef63833d
LP
155#define N_IOVEC_KERNEL_FIELDS 64
156#define N_IOVEC_UDEV_FIELDS 32
704e4fe7 157#define N_IOVEC_OBJECT_FIELDS 12
282c5c4e 158#define N_IOVEC_PAYLOAD_FIELDS 15
ef63833d 159
3b3154df 160void server_dispatch_message(Server *s, struct iovec *iovec, unsigned n, unsigned m, const struct ucred *ucred, const struct timeval *tv, const char *label, size_t label_len, const char *unit_id, int priority, pid_t object_pid);
8a03c9ef 161void server_driver_message(Server *s, sd_id128_t message_id, const char *format, ...) _printf_(3,0) _sentinel_;
ef63833d 162
e6960940
LP
163/* gperf lookup function */
164const struct ConfigPerfItem* journald_gperf_lookup(const char *key, unsigned length);
165
71a61510 166int config_parse_storage(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);
e156d769 167
44a6b1b6
ZJS
168const char *storage_to_string(Storage s) _const_;
169Storage storage_from_string(const char *s) _pure_;
182b858f 170
71a61510 171int config_parse_split_mode(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);
182b858f 172
44a6b1b6
ZJS
173const char *split_mode_to_string(SplitMode s) _const_;
174SplitMode split_mode_from_string(const char *s) _pure_;
d025f1e4 175
d025f1e4
ZJS
176int server_init(Server *s);
177void server_done(Server *s);
26687bf8 178void server_sync(Server *s);
8580d1f7 179int server_vacuum(Server *s, bool verbose, bool patch_min_use);
d025f1e4 180void server_rotate(Server *s);
d07f7b9e 181int server_schedule_sync(Server *s, int priority);
d025f1e4 182int server_flush_to_var(Server *s);
d025f1e4 183void server_maybe_append_tags(Server *s);
8531ae70 184int server_process_datagram(sd_event_source *es, int fd, uint32_t revents, void *userdata);