How does NOW work?2019 Community Moderator ElectionWhat does the DIP opcode in Michelson do?How can I deploy a Michelson smart contract?How SET_CAR/SET_CDR macros should be expanded?What is the BigMap container and why does it matter?
What wound would be of little consequence to a biped but terrible for a quadruped?
What are the practical Opportunty Attack values for a bugbear, holding a reach weapon, with Polearm Mastery?
Can you reject a postdoc offer after the PI has paid a large sum for flights/accommodation for your visit?
What is the magic ball of every day?
When traveling to Europe from North America, do I need to purchase a different power strip?
Counting all the hearts
How is the wildcard * interpreted as a command?
meaning and function of 幸 in "则幸分我一杯羹"
When stopping and starting a tile job, what to do with the extra thinset from previous row's cleanup?
Bash script should only kill those instances of another script's that it has launched
Plausibility of Mushroom Buildings
Do I really need to have a scientific explanation for my premise?
Accepted offer letter, position changed
Is it "Vierergruppe" or "Viergruppe", or is there a distinction?
Are there historical instances of the capital of a colonising country being temporarily or permanently shifted to one of its colonies?
Find longest word in a string: are any of these algorithms good?
Are babies of evil humanoid species inherently evil?
An alternative proof of an application of Hahn-Banach
Can one live in the U.S. and not use a credit card?
Does "Until when" sound natural for native speakers?
How to secure an aircraft at a transient parking space?
NASA's RS-25 Engines shut down time
How can The Temple of Elementary Evil reliably protect itself against kinetic bombardment?
How to draw cubes in a 3 dimensional plane
How does NOW work?
2019 Community Moderator ElectionWhat does the DIP opcode in Michelson do?How can I deploy a Michelson smart contract?How SET_CAR/SET_CDR macros should be expanded?What is the BigMap container and why does it matter?
Say a contract has a condition based on NOW being after a time. Is NOW UTC, and is this validated by each node before being added to the chain? Let's say you want ensure a function is called during a 1 hour window, will this be possible to enforce?
For example:
current stack state: NOW - 15 minutes :: NOW + 45 minutes //pseudocode
code: NOW; SUB; GT; SWAP;
NOW; SWAP; SUB;
AND;
IF send transaction... FAIL; ;
This should check that it's greater than NOW - 15 minutes and less than NOW + 45 minutes, which are both true so it can execute the transaction.
It might also be important to understand how the network gets consensus on a block time across the network?
michelson
add a comment |
Say a contract has a condition based on NOW being after a time. Is NOW UTC, and is this validated by each node before being added to the chain? Let's say you want ensure a function is called during a 1 hour window, will this be possible to enforce?
For example:
current stack state: NOW - 15 minutes :: NOW + 45 minutes //pseudocode
code: NOW; SUB; GT; SWAP;
NOW; SWAP; SUB;
AND;
IF send transaction... FAIL; ;
This should check that it's greater than NOW - 15 minutes and less than NOW + 45 minutes, which are both true so it can execute the transaction.
It might also be important to understand how the network gets consensus on a block time across the network?
michelson
add a comment |
Say a contract has a condition based on NOW being after a time. Is NOW UTC, and is this validated by each node before being added to the chain? Let's say you want ensure a function is called during a 1 hour window, will this be possible to enforce?
For example:
current stack state: NOW - 15 minutes :: NOW + 45 minutes //pseudocode
code: NOW; SUB; GT; SWAP;
NOW; SWAP; SUB;
AND;
IF send transaction... FAIL; ;
This should check that it's greater than NOW - 15 minutes and less than NOW + 45 minutes, which are both true so it can execute the transaction.
It might also be important to understand how the network gets consensus on a block time across the network?
michelson
Say a contract has a condition based on NOW being after a time. Is NOW UTC, and is this validated by each node before being added to the chain? Let's say you want ensure a function is called during a 1 hour window, will this be possible to enforce?
For example:
current stack state: NOW - 15 minutes :: NOW + 45 minutes //pseudocode
code: NOW; SUB; GT; SWAP;
NOW; SWAP; SUB;
AND;
IF send transaction... FAIL; ;
This should check that it's greater than NOW - 15 minutes and less than NOW + 45 minutes, which are both true so it can execute the transaction.
It might also be important to understand how the network gets consensus on a block time across the network?
michelson
michelson
asked 15 hours ago
RobRob
2685
2685
add a comment |
add a comment |
3 Answers
3
active
oldest
votes
There is an assumption that all Tezos nodes are synchronized, otherwise the consensus with 1-minute slots would not work. Of course, some delay is ok, but more than a few seconds might prevent a baker from baking.
NOW is the time at which the block, containing the transaction, should be baked. So, the baker knows the last block time, he knows his slot, so he can compute the time at which he should bake the block. It then uses that time to execute the transactions.
add a comment |
Nodes time being synchronized is only part of the picture: bakers can always be offline for their own reasons, the network can be stalled, many other transactions could be competing to get selected by bakers, etc. so people need to be very cautious and give plenty of time for an event to occur.
I would say that a few minutes or even hours is not enough today.
Is one day enough ? I would tend to think so but I'm not even certain.
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
1
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
add a comment |
The baker chooses the value of NOW. I am aware of these two constraints:
The protocol enforces that the timestamp is at least the minimal timestamp at which the baker was supposed to bake (some delay after the previous block's timestamp): baking.ml.
The shell will also ignore a block whose timestamp is too far in the future (more than 15s) relative to the system clock: distributed_db.ml.
add a comment |
Your Answer
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "698"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
noCode: true, onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftezos.stackexchange.com%2fquestions%2f735%2fhow-does-now-work%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
3 Answers
3
active
oldest
votes
3 Answers
3
active
oldest
votes
active
oldest
votes
active
oldest
votes
There is an assumption that all Tezos nodes are synchronized, otherwise the consensus with 1-minute slots would not work. Of course, some delay is ok, but more than a few seconds might prevent a baker from baking.
NOW is the time at which the block, containing the transaction, should be baked. So, the baker knows the last block time, he knows his slot, so he can compute the time at which he should bake the block. It then uses that time to execute the transactions.
add a comment |
There is an assumption that all Tezos nodes are synchronized, otherwise the consensus with 1-minute slots would not work. Of course, some delay is ok, but more than a few seconds might prevent a baker from baking.
NOW is the time at which the block, containing the transaction, should be baked. So, the baker knows the last block time, he knows his slot, so he can compute the time at which he should bake the block. It then uses that time to execute the transactions.
add a comment |
There is an assumption that all Tezos nodes are synchronized, otherwise the consensus with 1-minute slots would not work. Of course, some delay is ok, but more than a few seconds might prevent a baker from baking.
NOW is the time at which the block, containing the transaction, should be baked. So, the baker knows the last block time, he knows his slot, so he can compute the time at which he should bake the block. It then uses that time to execute the transactions.
There is an assumption that all Tezos nodes are synchronized, otherwise the consensus with 1-minute slots would not work. Of course, some delay is ok, but more than a few seconds might prevent a baker from baking.
NOW is the time at which the block, containing the transaction, should be baked. So, the baker knows the last block time, he knows his slot, so he can compute the time at which he should bake the block. It then uses that time to execute the transactions.
answered 10 hours ago
lefessanlefessan
2,557522
2,557522
add a comment |
add a comment |
Nodes time being synchronized is only part of the picture: bakers can always be offline for their own reasons, the network can be stalled, many other transactions could be competing to get selected by bakers, etc. so people need to be very cautious and give plenty of time for an event to occur.
I would say that a few minutes or even hours is not enough today.
Is one day enough ? I would tend to think so but I'm not even certain.
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
1
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
add a comment |
Nodes time being synchronized is only part of the picture: bakers can always be offline for their own reasons, the network can be stalled, many other transactions could be competing to get selected by bakers, etc. so people need to be very cautious and give plenty of time for an event to occur.
I would say that a few minutes or even hours is not enough today.
Is one day enough ? I would tend to think so but I'm not even certain.
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
1
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
add a comment |
Nodes time being synchronized is only part of the picture: bakers can always be offline for their own reasons, the network can be stalled, many other transactions could be competing to get selected by bakers, etc. so people need to be very cautious and give plenty of time for an event to occur.
I would say that a few minutes or even hours is not enough today.
Is one day enough ? I would tend to think so but I'm not even certain.
Nodes time being synchronized is only part of the picture: bakers can always be offline for their own reasons, the network can be stalled, many other transactions could be competing to get selected by bakers, etc. so people need to be very cautious and give plenty of time for an event to occur.
I would say that a few minutes or even hours is not enough today.
Is one day enough ? I would tend to think so but I'm not even certain.
answered 8 hours ago
FFFFFF
606212
606212
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
1
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
add a comment |
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
1
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
If I'm experimenting with building something that can hit milestones during smaller ranges. Kind of curious how close those milestones can be.
– Rob
6 hours ago
1
1
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
Understood but let's all remember Fomo3d medium.com/coinmonks/… on Ethereum before requiring milestones too fast.
– FFF
5 hours ago
add a comment |
The baker chooses the value of NOW. I am aware of these two constraints:
The protocol enforces that the timestamp is at least the minimal timestamp at which the baker was supposed to bake (some delay after the previous block's timestamp): baking.ml.
The shell will also ignore a block whose timestamp is too far in the future (more than 15s) relative to the system clock: distributed_db.ml.
add a comment |
The baker chooses the value of NOW. I am aware of these two constraints:
The protocol enforces that the timestamp is at least the minimal timestamp at which the baker was supposed to bake (some delay after the previous block's timestamp): baking.ml.
The shell will also ignore a block whose timestamp is too far in the future (more than 15s) relative to the system clock: distributed_db.ml.
add a comment |
The baker chooses the value of NOW. I am aware of these two constraints:
The protocol enforces that the timestamp is at least the minimal timestamp at which the baker was supposed to bake (some delay after the previous block's timestamp): baking.ml.
The shell will also ignore a block whose timestamp is too far in the future (more than 15s) relative to the system clock: distributed_db.ml.
The baker chooses the value of NOW. I am aware of these two constraints:
The protocol enforces that the timestamp is at least the minimal timestamp at which the baker was supposed to bake (some delay after the previous block's timestamp): baking.ml.
The shell will also ignore a block whose timestamp is too far in the future (more than 15s) relative to the system clock: distributed_db.ml.
answered 4 hours ago
TomTom
87327
87327
add a comment |
add a comment |
Thanks for contributing an answer to Tezos Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftezos.stackexchange.com%2fquestions%2f735%2fhow-does-now-work%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
-michelson