神刀安全网

P2p Redux with Redux-swarmlog

Redux Swarmlog

P2p Redux with Redux-swarmlog

(Click image to watch React Europe lightning video)

P2p Redux with Redux-swarmlog

(Click image to watch Egghead.io intro video)

A super simple way of writing distributed Redux applications. TheRedux action log is persisted in an IndexDB and synced with other peers via aWebRTC Swarm usingSwarmlog.

When an application reloads the Redux store is initialsed by reducing all the persisted actions in the IndexDB and syncing any new actions from remote peers. Watch the Egghead video above to find out more.

Pros

  • offline data by default
  • super simple mental model for writing distributed apps
  • UIs update automatically as remote actions come in
  • works offline by default
  • scales globally for free with no bandwidth or storage costs for the developer
  • the developer is not responsible for client data
  • friends not cooperations hold user data
  • public / private key authentication is lighter weight than user accounts
  • time travel

Cons

  • Action logs use more bandwidth than raw data so initial sync could be slow for a very long log.

    workaround:Break down long logs into lots of smaller logs e.g. log per month, week or day. Only fetch the most recent log if its all thats needed

  • Extra storage space needed on client

    workaround:The price of SSDs is falling very rapidly. Stop thinking about cloud and thin client, but cache encrypted data where it is needed. This gives privacy, enables working offline, provides backups and can act as a CDN. Once you start using a distributed system like Git you soon stop thinking about the extra space it requires.

  • Permanence: even if an action deletes an item it can still be retrieved from the log.

    workaround:Use a log for versioning other logs. Every so often the main log is reduced and a single action is written to a new log which creates the store in the current state. The old log is marked as stale in the version log and its database is deleted (purging old actions).

  • Can’t get most up to date data if the peer holding it is offline

    workaround:A small device like a Raspberry PI kept online should be all that is needed to make sure there is always at least one up to date source of truth. With 5G and IoT we are heading towards an era of always online small connected devices. Let’s start thinking that way now.

Play to Strengths

Redux Swarmlog works well for apps that support some kind of physical live event. Because you know the action log will be short and the users will be online at the same time. Examples might be providing subtitles via mobile phone for a theatre show or letting a teacher see in realtime how each individuals in a class is answering a question.

转载本站任何文章请注明:转载至神刀安全网,谢谢神刀安全网 » P2p Redux with Redux-swarmlog

分享到:更多 ()

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址