Difference between revisions of "Proxyd"

From wikieduonline
Jump to navigation Jump to search
 
(62 intermediate revisions by the same user not shown)
Line 1: Line 1:
* https://github.com/ethereum-optimism/optimism/tree/develop/proxyd
+
{{lc}}<code>proxyd</code> is an [[RPC]] [[proxy]]
 +
* https://github.com/ethereum-optimism/infra/tree/main/proxyd
  
 +
* Changelog: https://github.com/ethereum-optimism/infra/blob/main/proxyd/CHANGELOG.md
 +
* Config: https://github.com/ethereum-optimism/infra/blob/main/proxyd/config.go
 +
** [[Proxyd config example]]: https://github.com/ethereum-optimism/infra/blob/main/proxyd/example.config.toml
 +
** proxyd /etc/proxyd/[[proxyd.toml]]: <code>[[ws_method_whitelist]], [[response_timeout_seconds]], [[out_of_service_seconds]], [[max_latency_threshold]]</code>
 +
* Releases: https://github.com/ethereum-optimism/infra/tags
  
 +
Features:
 +
* [[Whitelists]] [[RPC methods]] (<code>[[ws_method_whitelist]]</code>)
 +
* Routes RPC methods to groups of backend services
 +
* [[Round-robin]] [[Load balance]] requests across [[backend]] services
 +
* Automatically [[retries]] failed backend requests
 +
* Cache immutable responses from backends
 +
* Provides metrics to measure request latency, error rates
  
* {{Optimism}}
+
[[Consensus]] related:
 +
* Track backend consensus (latest, safe, finalized blocks), peer count and sync state
 +
* Re-write requests and responses to enforce consensus
 +
 
 +
 
 +
* Applies [[rate limiting]] (<code>[[SenderRateLimitConfig]]</code>) on a per-sender basis to avoid being bombarded with signed transactions causing a DOS (Denial of Service) of the sequencer ([[Optimism Censorship Bug Disclosure]])
 +
 
 +
== [[Proxyd backend healthy]] ==
 +
 
 +
 
 +
== Errors examples ==
 +
[[Failed sync attempt]] to a7eaa64c50083f1xxxxxfd96eaabffd1c8f: one or more objects failed to apply, reason: error when patching
 +
"/dev/shm/396xxxxx68": Deployment.apps "your-service" is invalid: spec.template.spec.containers[0].env[1].valueFrom: Invalid value: "": may not
 +
be specified when `value` is not empty (retried 1 times).
 +
 
 +
== [[Proxyd logs]] ==
 +
 
 +
== Activities ==
 +
* Read [[Optimism Censorship Bug Disclosure]]
 +
 
 +
== Related ==
 +
* [[Consensus]]
 +
* [[Emerald Dshackle]] [[load balancer]]
 +
* [[dRPC]]
 +
* [[Total number of primary candidates]]
 +
* [[RedisConfig]]
 +
* [[Fallback]]
 +
 
 +
== See also ==
 +
* {{proxyd}}
 +
* {{op-}}
 +
 
 +
[[Category:Optisism]]

Latest revision as of 12:49, 21 October 2024

proxyd is an RPC proxy

Features:

Consensus related:

  • Track backend consensus (latest, safe, finalized blocks), peer count and sync state
  • Re-write requests and responses to enforce consensus


Proxyd backend healthy[edit]

Errors examples[edit]

Failed sync attempt to a7eaa64c50083f1xxxxxfd96eaabffd1c8f: one or more objects failed to apply, reason: error when patching 
"/dev/shm/396xxxxx68": Deployment.apps "your-service" is invalid: spec.template.spec.containers[0].env[1].valueFrom: Invalid value: "": may not 
be specified when `value` is not empty (retried 1 times).

Proxyd logs[edit]

Activities[edit]

Related[edit]

See also[edit]

Advertising: