Skip to content

Commit

Permalink
use std::time instead of crate time
Browse files Browse the repository at this point in the history
  • Loading branch information
Keksoj committed Apr 24, 2024
1 parent 5ce5c5a commit f84cdeb
Show file tree
Hide file tree
Showing 17 changed files with 100 additions and 116 deletions.
1 change: 0 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion bin/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ paw = "^1.0.0"
serde = { version = "^1.0.197", features = ["derive"] }
serde_json = "^1.0.116"
prost = "^0.12.4"
time = "^0.3.36"
# time = "^0.3.36"
tempfile = "^3.10.1"
termion = "^3.0.0"
thiserror = "^1.0.58"
Expand Down
11 changes: 5 additions & 6 deletions command/src/logging/access_logs.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
use std::{collections::BTreeMap, mem::ManuallyDrop, net::SocketAddr};
use std::{collections::BTreeMap, mem::ManuallyDrop, net::SocketAddr, time::Duration};

use rusty_ulid::Ulid;
use time::Duration;

use crate::{
logging::{LogLevel, Rfc3339Time},
Expand Down Expand Up @@ -160,17 +159,17 @@ impl RequestRecord<'_> {
backend_id: self.context.backend_id.duplicate(),
bytes_in: self.bytes_in as u64,
bytes_out: self.bytes_out as u64,
client_rtt: self.client_rtt.map(|t| t.whole_microseconds() as u64),
client_rtt: self.client_rtt.map(|t| t.as_micros() as u64),
cluster_id: self.context.cluster_id.duplicate(),
endpoint: ProtobufEndpoint {
inner: Some(endpoint),
},
message: self.message.duplicate(),
protocol: self.protocol.duplicate(),
request_id: self.context.request_id.into(),
response_time: self.response_time.whole_microseconds() as u64,
server_rtt: self.server_rtt.map(|t| t.whole_microseconds() as u64),
service_time: self.service_time.whole_microseconds() as u64,
response_time: self.response_time.as_micros() as u64,
server_rtt: self.server_rtt.map(|t| t.as_micros() as u64),
service_time: self.service_time.as_micros() as u64,
session_address: self.session_address.map(Into::into),
tags: self
.tags
Expand Down
8 changes: 4 additions & 4 deletions command/src/logging/display.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,19 +77,19 @@ impl fmt::Display for LogDuration {
match self.0 {
None => write!(f, "-"),
Some(duration) => {
let secs = duration.whole_seconds();
let secs = duration.as_secs();
if secs >= 10 {
return write!(f, "{secs}s");
}

let ms = duration.whole_milliseconds();
let ms = duration.as_millis();
if ms < 10 {
let us = duration.whole_microseconds();
let us = duration.as_millis();
if us >= 10 {
return write!(f, "{us}μs");
}

let ns = duration.whole_nanoseconds();
let ns = duration.as_nanos();
return write!(f, "{ns}ns");
}

Expand Down
1 change: 1 addition & 0 deletions command/src/logging/logs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1007,6 +1007,7 @@ pub struct Rfc3339Time {
pub inner: ::time::OffsetDateTime,
}

/// yields (Rfc3339Time, unix_epoch)
pub fn now() -> (Rfc3339Time, i128) {
let t = time::OffsetDateTime::now_utc();
(
Expand Down
5 changes: 2 additions & 3 deletions lib/src/backends.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
use std::{cell::RefCell, collections::HashMap, net::SocketAddr, rc::Rc};
use std::{cell::RefCell, collections::HashMap, net::SocketAddr, rc::Rc, time::Duration};

use mio::net::TcpStream;
use time::Duration;

use sozu_command::{
proto::command::{Event, EventKind, LoadBalancingAlgorithms, LoadBalancingParams, LoadMetric},
Expand Down Expand Up @@ -130,7 +129,7 @@ impl Backend {
}

pub fn set_connection_time(&mut self, dur: Duration) {
self.connection_time.observe(dur.whole_nanoseconds() as f64);
self.connection_time.observe(dur.as_nanos() as f64);
}

pub fn peak_ewma_connection(&mut self) -> f64 {
Expand Down
16 changes: 6 additions & 10 deletions lib/src/http.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ use std::{
os::unix::io::AsRawFd,
rc::{Rc, Weak},
str::from_utf8_unchecked,
time::{Duration, Instant},
};

use mio::{
Expand All @@ -14,7 +15,6 @@ use mio::{
Interest, Registry, Token,
};
use rusty_ulid::Ulid;
use time::{Duration, Instant};

use sozu_command::{
logging::CachedTags,
Expand Down Expand Up @@ -473,11 +473,7 @@ impl L7ListenerHandler for HttpListener {
let now = Instant::now();

if let Route::ClusterId(cluster) = &route {
time!(
"frontend_matching_time",
cluster,
(now - start).whole_milliseconds()
);
time!("frontend_matching_time", cluster, (now - start).as_millis());
}

Ok(route)
Expand Down Expand Up @@ -921,10 +917,10 @@ impl ProxyConfiguration for HttpProxy {

let session = HttpSession::new(
owned.answers.clone(),
Duration::seconds(owned.config.back_timeout as i64),
Duration::seconds(owned.config.connect_timeout as i64),
Duration::seconds(owned.config.front_timeout as i64),
Duration::seconds(owned.config.request_timeout as i64),
Duration::from_secs(owned.config.back_timeout as u64),
Duration::from_secs(owned.config.connect_timeout as u64),
Duration::from_secs(owned.config.front_timeout as u64),
Duration::from_secs(owned.config.request_timeout as u64),
owned.config.expect_proxy,
listener.clone(),
Rc::downgrade(&self.pool),
Expand Down
16 changes: 6 additions & 10 deletions lib/src/https.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ use std::{
rc::{Rc, Weak},
str::{from_utf8, from_utf8_unchecked},
sync::Arc,
time::{Duration, Instant},
};

use mio::{
Expand All @@ -32,7 +33,6 @@ use rustls::{
SupportedCipherSuite,
};
use rusty_ulid::Ulid;
use time::{Duration, Instant};

use sozu_command::{
certificate::Fingerprint,
Expand Down Expand Up @@ -607,11 +607,7 @@ impl L7ListenerHandler for HttpsListener {
let now = Instant::now();

if let Route::ClusterId(cluster) = &route {
time!(
"frontend_matching_time",
cluster,
(now - start).whole_milliseconds()
);
time!("frontend_matching_time", cluster, (now - start).as_millis());
}

Ok(route)
Expand Down Expand Up @@ -1232,10 +1228,10 @@ impl ProxyConfiguration for HttpsProxy {

let session = Rc::new(RefCell::new(HttpsSession::new(
owned.answers.clone(),
Duration::seconds(owned.config.back_timeout as i64),
Duration::seconds(owned.config.connect_timeout as i64),
Duration::seconds(owned.config.front_timeout as i64),
Duration::seconds(owned.config.request_timeout as i64),
Duration::from_secs(owned.config.back_timeout as u64),
Duration::from_secs(owned.config.connect_timeout as u64),
Duration::from_secs(owned.config.front_timeout as u64),
Duration::from_secs(owned.config.request_timeout as u64),
owned.config.expect_proxy,
listener.clone(),
Rc::downgrade(&self.pool),
Expand Down
32 changes: 12 additions & 20 deletions lib/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -343,6 +343,7 @@ use std::{
net::SocketAddr,
rc::Rc,
str,
time::{Duration, Instant},
};

use backends::BackendError;
Expand All @@ -351,7 +352,6 @@ use mio::{net::TcpStream, Interest, Token};
use protocol::http::{answers::TemplateError, parser::Method};
use router::RouterError;
use socket::ServerBindError;
use time::{Duration, Instant};
use tls::CertificateResolverError;

use sozu_command::{
Expand Down Expand Up @@ -945,8 +945,8 @@ impl SessionMetrics {
pub fn new(wait_time: Option<Duration>) -> SessionMetrics {
SessionMetrics {
start: Some(Instant::now()),
service_time: Duration::seconds(0),
wait_time: wait_time.unwrap_or_else(|| Duration::seconds(0)),
service_time: Duration::from_secs(0),
wait_time: wait_time.unwrap_or_else(|| Duration::from_secs(0)),
bin: 0,
bout: 0,
service_start: None,
Expand All @@ -962,8 +962,8 @@ impl SessionMetrics {

pub fn reset(&mut self) {
self.start = None;
self.service_time = Duration::seconds(0);
self.wait_time = Duration::seconds(0);
self.service_time = Duration::from_secs(0);
self.wait_time = Duration::from_secs(0);
self.bin = 0;
self.bout = 0;
self.service_start = None;
Expand Down Expand Up @@ -1009,7 +1009,7 @@ impl SessionMetrics {
pub fn response_time(&self) -> Duration {
match self.start {
Some(start) => Instant::now() - start,
None => Duration::seconds(0),
None => Duration::from_secs(0),
}
}

Expand Down Expand Up @@ -1045,26 +1045,18 @@ impl SessionMetrics {
let service_time = self.service_time();

if let Some(cluster_id) = context.cluster_id {
time!(
"response_time",
cluster_id,
response_time.whole_milliseconds()
);
time!(
"service_time",
cluster_id,
service_time.whole_milliseconds()
);
time!("response_time", cluster_id, response_time.as_millis());
time!("service_time", cluster_id, service_time.as_millis());
}
time!("response_time", response_time.whole_milliseconds());
time!("service_time", service_time.whole_milliseconds());
time!("response_time", response_time.as_millis());
time!("service_time", service_time.as_millis());

if let Some(backend_id) = self.backend_id.as_ref() {
if let Some(backend_response_time) = self.backend_response_time() {
record_backend_metrics!(
context.cluster_id.as_str_or("-"),
backend_id,
backend_response_time.whole_milliseconds(),
backend_response_time.as_millis(),
self.backend_connection_time(),
self.backend_bin,
self.backend_bout
Expand Down Expand Up @@ -1121,7 +1113,7 @@ impl PeakEWMA {
self.rtt = rtt;
} else {
// new_rtt = old_rtt * e^(-elapsed/decay) + observed_rtt * (1 - e^(-elapsed/decay))
let weight = (-1.0 * dur.whole_nanoseconds() as f64 / self.decay).exp();
let weight = (-1.0 * dur.as_nanos() as f64 / self.decay).exp();
self.rtt = self.rtt * weight + rtt * (1.0 - weight);
}

Expand Down
2 changes: 1 addition & 1 deletion lib/src/metrics/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -403,7 +403,7 @@ macro_rules! record_backend_metrics (
m.receive_metric("bytes_out", Some(cluster_id), Some(backend_id), MetricValue::Count($bout as i64));
m.receive_metric("backend_response_time", Some(cluster_id), Some(backend_id), MetricValue::Time($response_time as usize));
if let Some(t) = $backend_connection_time {
m.receive_metric("backend_connection_time", Some(cluster_id), Some(backend_id), MetricValue::Time(t.whole_milliseconds() as usize));
m.receive_metric("backend_connection_time", Some(cluster_id), Some(backend_id), MetricValue::Time(t.as_millis() as usize));
}

m.receive_metric("requests", Some(cluster_id), Some(backend_id), MetricValue::Count(1));
Expand Down
13 changes: 7 additions & 6 deletions lib/src/protocol/kawa_h1/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ use std::{
io::ErrorKind,
net::{Shutdown, SocketAddr},
rc::{Rc, Weak},
time::{Duration, Instant},
};

use mio::{net::TcpStream, Interest, Token};
Expand All @@ -17,7 +18,7 @@ use sozu_command::{
logging::EndpointRecord,
proto::command::{Event, EventKind, ListenerType},
};
use time::{Duration, Instant};
// use time::{Duration, Instant};

use crate::{
backends::{Backend, BackendError},
Expand Down Expand Up @@ -1052,7 +1053,7 @@ impl<Front: SocketHandler, L: ListenerHandler + L7ListenerHandler> Http<Front, L
Some(stop_instant) => {
let now = Instant::now();
let dur = now - *stop_instant;
if dur > Duration::seconds(1) {
if dur > Duration::from_secs(1) {
return self.test_backend_socket();
}
}
Expand Down Expand Up @@ -1844,7 +1845,7 @@ impl<Front: SocketHandler, L: ListenerHandler + L7ListenerHandler> SessionState
// we do not have a complete answer
TimeoutStatus::Request => {
self.set_answer(DefaultAnswer::Answer408 {
duration: self.container_frontend_timeout.duration().to_string(),
duration: self.container_frontend_timeout.duration_fmt(),
});
self.writable(metrics)
}
Expand All @@ -1853,7 +1854,7 @@ impl<Front: SocketHandler, L: ListenerHandler + L7ListenerHandler> SessionState
// this case is ambiguous, as it is the frontend timeout that triggers while we were waiting for response
// the timeout responsibility should have switched before
self.set_answer(DefaultAnswer::Answer504 {
duration: self.container_backend_timeout.duration().to_string(),
duration: self.container_backend_timeout.duration_fmt(),
});
self.writable(metrics)
}
Expand All @@ -1874,13 +1875,13 @@ impl<Front: SocketHandler, L: ListenerHandler + L7ListenerHandler> SessionState
"got backend timeout while waiting for a request, this should not happen"
);
self.set_answer(DefaultAnswer::Answer504 {
duration: self.container_backend_timeout.duration().to_string(),
duration: self.container_backend_timeout.duration_fmt(),
});
self.writable(metrics)
}
TimeoutStatus::WaitingForResponse => {
self.set_answer(DefaultAnswer::Answer504 {
duration: self.container_backend_timeout.duration().to_string(),
duration: self.container_backend_timeout.duration_fmt(),
});
self.writable(metrics)
}
Expand Down
5 changes: 2 additions & 3 deletions lib/src/protocol/proxy_protocol/expect.rs
Original file line number Diff line number Diff line change
Expand Up @@ -310,10 +310,9 @@ mod expect_test {
net::{IpAddr, Ipv4Addr, SocketAddr},
sync::{Arc, Barrier},
thread::{self, JoinHandle},
time::Duration,
};

use time::Duration;

use crate::protocol::proxy_protocol::header::*;

// Flow diagram of the test below
Expand Down Expand Up @@ -349,7 +348,7 @@ mod expect_test {
}

let mut session_metrics = SessionMetrics::new(None);
let container_frontend_timeout = TimeoutContainer::new(Duration::seconds(10), Token(0));
let container_frontend_timeout = TimeoutContainer::new(Duration::from_secs(10), Token(0));
let mut expect_pp = ExpectProxyProtocol::new(
container_frontend_timeout,
session_stream,
Expand Down
7 changes: 3 additions & 4 deletions lib/src/router/mod.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
pub mod pattern_trie;
pub mod trie;

use std::str::from_utf8;
use std::{str::from_utf8, time::Instant};

use regex::bytes::Regex;
use time::Instant;

use sozu_command::{
proto::command::{PathRule as CommandPathRule, PathRuleKind, RulePosition},
Expand Down Expand Up @@ -441,7 +440,7 @@ impl DomainRule {
let start = Instant::now();
let is_a_match = r.is_match(hostname);
let now = Instant::now();
time!("regex_matching_time", (now - start).whole_milliseconds());
time!("regex_matching_time", (now - start).as_millis());
is_a_match
}
}
Expand Down Expand Up @@ -521,7 +520,7 @@ impl PathRule {
let start = Instant::now();
let is_a_match = regex.is_match(path);
let now = Instant::now();
time!("regex_matching_time", (now - start).whole_milliseconds());
time!("regex_matching_time", (now - start).as_millis());

if is_a_match {
PathRuleResult::Regex
Expand Down
Loading

0 comments on commit f84cdeb

Please sign in to comment.